当前位置: 首页 > news >正文

画册设计网站推荐搜索引擎优化规则

画册设计网站推荐,搜索引擎优化规则,搬瓦工做网站方法,网站查找工具本文为Python算法题集之一的代码示例 题目3:无重复字符的最长子串 说明:给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 示例 1: 输入: s "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "a…

本文为Python算法题集之一的代码示例

题目3:无重复字符的最长子串

说明:给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。

示例 1:

输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

示例 2:

输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。

示例 3:

输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

- 感慨:本题很特殊,特别特殊,超级无敌特殊!!!

程序员没有一个没写过字符串处理,没有一个没写过查找字符串子串

问题是谁都能写,可是写出来就是原形毕露,稍不留神,就要贻笑大方

大虾们是高手,十年练剑,深藏不露,都是传说中十步杀一人,千里不留行的人物

如果本文写得笨拙浅薄,还请大虾们多多包涵,高抬贵手~~


本题求解有两个重点工作

一是在子串中进行字符查重

可以使用基本查重【集合中查询子元素】、字典查重【哈希值,值为数字】、下标查重【ord(char)为下标,数组元素为数字】

二是对字符串进行遍历找出所有子串

可使用双重循环、单循环单指针、双指针【滑动窗口】


注意:代码运行每次速度都不同,估计服务器负载有波动

注意:代码运行每次速度都不同,估计服务器负载有波动

注意:代码运行每次速度都不同,估计服务器负载有波动


  1. 新手基本型【基本查重+双重循环】,无脑遍历,注定超时

    ​ 用双重循环遍历所有子串,字符查重则可以采用集合set去重查重或者字符串查子串函数查重。此算法颇为无脑,算是初学程序者的作品,肯定会超时,就不给它表现的机会了

    def longest_unique_substr_newbie(s):  # 双循环遍历、集合查重iLen=len(s)iMaxsublen=0for iIdx in range(iLen):for iJdx in range(iIdx+1, iLen-1):if len(set(s[iIdx:iJdx])) == iJdx-iIdx:iMaxsublen = max(iMaxsublen, iJdx-iIdx)return iMaxsublenprint(longest_unique_substr_newbie('abcabcbb'))
    # 运行结果 
    3
    

  1. 下标查重+双重循环,有所改善,超过77%
    在这里插入图片描述

    def longest_unique_substr_ext1(s):  # 下标查重+双重循环iLen = len(s)iMaxsublen = 0icharcount = [0] * 128ileft, iright = 0, 0while iright < iLen:icharcount[ord(s[iright])] += 1while icharcount[ord(s[iright])] > 1:icharcount[ord(s[ileft])] -= 1ileft += 1iMaxsublen = max(iMaxsublen, iright - ileft + 1)iright += 1return iMaxsublenprint(longest_unique_substr_ext1('abcabcbb'))
    # 运行结果 
    3
    
  2. 字典查重【单判断】+双指针,有所改善,超过77%
    在这里插入图片描述

    def longest_unique_substr_ext2(s):  # 字典查重+双指针iLen = len(s)iMaxsublen = 0dictwindow = {}ileft, iright = 0, 0while iright < iLen:if s[iright] in dictwindow:ileft = max(ileft, dictwindow[s[iright]] + 1)dictwindow[s[iright]] = irightiMaxsublen = max(iMaxsublen, iright - ileft + 1)iright += 1return iMaxsublenprint(longest_unique_substr_ext2('abcabcbb'))
    # 运行结果 
    3
    
  3. 集合查重+双指针,表现良好,超过87%
    在这里插入图片描述

    def longest_unique_substr_ext3(s):  # 集合查重+双指针iLen=len(s)iMaxsublen, ileft, iright = 0, 0, 0set_substr = set()while iright<iLen:if s[iright] in set_substr:set_substr.remove(s[ileft])ileft += 1else:set_substr.add(s[iright])iMaxsublen = max(iMaxsublen, iright-ileft+1)iright+=1return iMaxsublenprint(longest_unique_substr_ext3('abcabcbb'))
    # 运行结果 
    3
    
  4. 集合查重+单循环单指针,有所改善,超过77%
    在这里插入图片描述

    def longest_unique_substr_ext4(s):  # 集合查重+单循环单指针iLen = len(s)iMaxsublen = 0set_substr = set()istart = 0for iIdx in range(iLen):while s[iIdx] in set_substr:set_substr.remove(s[istart])istart += 1set_substr.add(s[iIdx])iMaxsublen = max(iMaxsublen, iIdx - istart + 1)return iMaxsublenprint(longest_unique_substr_ext4('abcabcbb'))
    # 运行结果 
    3
    
  5. 下标查重+双指针,有所改善,超过76%
    在这里插入图片描述

    def longest_unique_substr_ext5(s):  # ASC码下标定位,双指针iLen = len(s)iMaxsublen = 0char_index = [-1] * 128ileft, iright = 0, 0while iright < iLen:if char_index[ord(s[iright])] >= ileft:ileft = char_index[ord(s[iright])] + 1char_index[ord(s[iright])] = irightiMaxsublen = max(iMaxsublen, iright - ileft + 1)iright += 1return iMaxsublenprint(longest_unique_substr_ext5('abcabcbb'))
    # 运行结果 
    3
    
  6. 字典查重【双判断】+双指针,表现良好,超过87%
    在这里插入图片描述

    def longest_unique_substr_ext6(s):  # 字典查重+双指针iLen = len(s)iMaxsublen = 0dictwindow = {}ileft, iright = 0, 0while iright < iLen:if s[iright] in dictwindow and dictwindow[s[iright]] >= ileft:ileft = dictwindow[s[iright]] + 1dictwindow[s[iright]] = irightiMaxsublen = max(iMaxsublen, iright - ileft + 1)iright += 1return iMaxsublenprint(longest_unique_substr_ext6('abcabcbb'))
    # 运行结果 
    3
    
  7. 下标查重+单循环单指针,表现良好,超过88
    在这里插入图片描述

    def longest_unique_substr_ext7(s):  # 下标查重+单循环单指针iLen = len(s)iMaxsublen, istart = 0, 0dictwindow = {}for iIdx in range(iLen):if s[iIdx] in dictwindow and dictwindow[s[iIdx]] >= istart:istart = dictwindow[s[iIdx]] + 1dictwindow[s[iIdx]] = iIdxiMaxsublen = max(iMaxsublen, iIdx - istart + 1)return iMaxsublenprint(longest_unique_substr_ext7('abcabcbb'))
    # 运行结果 
    3
    
  8. 下标查重+单循环单指针跳跃,华山论剑,谁是英雄!
    在这里插入图片描述

    def longest_unique_substr_ext8(s):  # 下标查重+单循环单指针iLen = len(s)iMaxsublen, istart = 0, 0listchar = [-1] * 128for iIdx in range(iLen):if listchar[ord(s[iIdx])] >= istart:istart = listchar[ord(s[iIdx])] + 1listchar[ord(s[iIdx])] = iIdxiMaxsublen = max(iMaxsublen, iIdx - istart + 1)return iMaxsublenprint(longest_unique_substr_ext8('abcabcbb'))
    # 运行结果 
    3
    

    一日练,一日功,一日不练十日空

    may the odds be ever in your favor ~

http://www.laogonggong.com/news/85017.html

相关文章:

  • 长沙做网站团队vivo即将发布的新手机
  • 寮步镇仿做网站国外app推广平台有哪些
  • 网站备案幕布申请托管竞价推广公司
  • 网站建设图文灰色seo推广
  • 枞阳做网站的企业招聘信息
  • 网站底部备案代码自己做网站的流程
  • 门户网站建设维护网站建设与维护工作待遇
  • 一站式做网站系统成都住建局官网报名入口网址
  • 深圳服装外贸网站建设用dw制作网站建设
  • 做平面图片的网站最佳线上网站制作模板
  • 北京网站推广seo优化如何升级wordpress
  • 网站开发需求说明书房地产建筑设计公司
  • 怎样下载网站模板服务器网站怎么用
  • 重庆科技建设信息网站旅游网站如何做推广
  • 温州好的网站推广高端品牌车
  • php做商品网站手机网站怎么推广
  • 什么是网站建设从哪些方面建设网站优秀网站开发商
  • 网站开发过程及要求免费的ai写作网站
  • 毕设做网站的系统概述怎么写网站的功能和作用
  • 网站源码大全 最新成都电商网站
  • 5173网站源码寿县住房与城乡建设局网站
  • 江门做网站哪家好专业做淘宝网站公司哪家好
  • 专题类的网站wordpress主题安装在哪里
  • 网站页面分析范文百度域名收录
  • 国外网站页面做多大专业模板建站软件
  • 在哪修改网站关键词制作网站公司哪个好
  • 做网站如何排版江苏省建设网站
  • 多语种外贸网站服务公司荡神
  • 潍坊地区网站制作上海建设工程咨询公司
  • 二手书网站建设中企动力邮箱手机版