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

网站建设蓝图ppt12306网站学生做

网站建设蓝图ppt,12306网站学生做,ftp和网站后台,做视频网站空间要多大给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串 的长度。 示例 1: 输入: s “abcabcbb” 输出: 3 解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。 示例 2: 输入: s “bbbbb” 输出: 1 解释: 因为无重复字符的最长子串是 “b”…

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

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

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

示例 3:
输入: s = “pwwkew”
输出: 3
解释: 因为无重复字符的最长子串是 “wke”,所以其长度为 3。

请注意,你的答案必须是 子串 的长度,“pwke” 是一个子序列,不是子串。

提示:

0 <= s.length <= 5 * 104
s 由英文字母、数字、符号和空格组成

看到这个题目,我最先想到的是python中set(集合)是储存不重复元素的数据结构。但很快又发现了题目隐藏的心机:需要的是子串的长度,而不是子序列的长度,就像提示中说的,也就是说,我们还需要考虑“顺序”这一信息,而set是无序的。
费尽心机用set写了答案,费尽心机通过了三个测试用例,最后提交才发现还是有bug,于是放弃去看题解,发现大家都用滑动窗、双指针、哈希。
在这里插入图片描述
于是在参考了几个答案之后,有了这份答案:

class Solution(object):def lengthOfLongestSubstring(self, s):""":type s: str:rtype: int"""max_len = cur_len = left = 0check = set()for i in range(len(s)):cur_len += 1while s[i] in check:check.remove(s[left])left += 1cur_len -= 1if cur_len > max_len : max_len = cur_lencheck.add(s[i])return max_len

在代码的循环中一共有四个部分:
1.当前长度+1
2.判断重复元素,将集合中左边元素移除
3.判断最大长度和当前长度关系,储存最大长度。
4.在集合中添加新元素。

需要注意的是:这四部分的顺序十分重要。
1:这部分应该在循环的最开始执行。因为每次循环都代表尝试将一个新的字符加入子串,所以需要先假设这个字符是有效的,然后后续逻辑再判断是否需要调整。它是基于“乐观假设”的第一步,后续部分需要验证这个假设是否成立。如果发现有重复字符,后续逻辑会调整长度。
2:这部分必须紧跟在“当前长度+1”之后。因为一旦发现重复字符,就需要调整子串的左边界,同时更新当前长度。它依赖于“当前长度+1”部分的假设,因为只有在尝试加入新字符后,才可能发现重复。它会直接影响“当前长度”,因为移除左侧字符会导致子串长度减小。它为后续的“添加新元素”部分铺平道路,确保集合中没有重复字符。
3:这部分应该在“判断重复元素”之后执行。因为只有在确保当前子串没有重复字符后,才能确定当前长度是否有效。它依赖于“判断重复元素”部分的结果,因为只有在移除重复字符后,当前子串才是有效的。它是整个算法的核心目标,即找到最长的无重复子串。
4:这部分应该在“判断重复元素”之后执行。因为只有在移除重复字符后,才能安全地真正将当前字符加入集合。它同样依赖于“判断重复元素”部分的结果,因为只有在移除重复字符后,集合中才没有重复元素。它为下一次循环的“当前长度+1”部分提供基础,即集合中已经包含当前字符。

同时需要注意:
判断是否在集合内的,和加入的都是s[i](新元素),remove的是s[left](列头元素)

http://www.dtcms.com/a/409666.html

相关文章:

  • 外贸工厂的网站建设汕头网站模板价格
  • 襄阳网站建设企业乐清城市网官网
  • 网络公司网站asp上海营业执照网上申请
  • 山东省建设管理中心网站首页百度一下建设部网站
  • 网站自适应手机端网站建设鞍山
  • 做平台网站要多久哪的网页设计培训好
  • 阿里能帮做网站吗wordpress文章加载慢6
  • 西安网站架设公司石家庄信息网官方网站
  • flash网站的制作wordpress宝塔安装
  • 金螳螂家装官网学生班级优化大师
  • 在线做带字头像的网站网站建设教程培训
  • 论述网站建设的步骤页面禁止访问
  • 做星座网站邀请推广app
  • 网站做淘宝客排名会掉吗微信小程序制作视频教程
  • 上海频道做网站怎么样免费外链工具
  • 水稻网站做go分析服务器租赁合同范本
  • 阿里云可以做几个网站代理ip自动提取网站源码
  • 广东省省建设厅网站企业优化网站
  • 网站开发进度缓慢兼容ie8的网站模板
  • 重庆网站关键词优化推广许昌网站建设费用
  • 建一个企业网站要花多少钱沧州免费网站建设
  • 祝贺公司网站上线美丽定制 网站模板
  • 做零食网站的选题理由免费行情软件app一个
  • 中国电力建设股份部官方网站网站优化细节
  • 长沙专业个人做网站哪家好vue 做pc网站
  • 怎么能创建自己的网站有哪些类型的网站
  • 前端效果网站深圳网站建设公司613
  • 傻瓜一键自助建站系统网站建设的主题
  • WordPress彻底清理插件深圳营销型网站建设优化
  • 杭州市萧山区哪家做网站的公司好天津市建设工程协会网站