leetcode 题目解析 第3题 无重复字符的最长子串

给定一个字符串 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 由英文字母、数字、符号和空格组成

💡分析:

1、不含重复字符的子串

2、求最长子串的长度

🫤思路:

以"s = abcabcbb"为例,以下是手动处理过程:

python 复制代码
a
ab
abc
abca  :字段重复,去除最左边的字符 a s[0]
bca
bcab  :字段重复,去除最左边的字符 b s[1]
cab 
cabc  :字段重复,去除最左边的字符 c s[2]
abc
abcb  :字段重复,去除最左边的字符 a s[3]
bcb   :字段重复,去除最左边的字符 b s[4]
cb
cbb   :字段重复,去除最左边的字符 c s[5]
bb    :字段重复,去除最左边的字符 b s[6]
b

综上所述:

1、需要一个循环遍历字段;

2、需要一个容器来存放子串字符,并通过该容器判断子串是否重复,考虑到子串可能很长,使用集合(set)比列表更适合,因为集合的查找性能更优;

3、需要一个变量,存放"子串最左边字符" 在"字段s"中的下标位置;

4、需要一个变量,用于存储最长子串的长度;

现在开始编写代码(python3):

python 复制代码
class Solution:
    def lengthOfLongestSubstring(self, s: str) -> int:
        # 定义一个集合,存放子串的字符
        child_set = set()
        # 定义一个变量,存放子串最左边字符在字段中的下标,初始下标为0
        left = 0
        # 定义一个变量,存放子串最大长度,初始值为0
        max_len = 0
        # 循环遍历字段s
        for sc in s:
            '''
            判断待添加字符加入集合是否会重复,如果重复,则删除子串最左侧字符
            '''
            # if sc in child_set:
                # child_set.remove(s[left])
                # left += 1
            '''
            因为删除的是最左侧的字符,而不是待添加字符,
            所以待添加字符在集合中可能还是会重复,
            所以这里需要一个while循环,而不是if
            '''
            while sc in child_set:
                child_set.remove(s[left])
                left += 1
            # 确保不重复后,将待添加字符,加入进集合
            child_set.add(sc)
            # 记录集合最大长度,即子串最大长度
            max_len = max(max_len,len(child_set))
        return max_len

然后,这就是 滑动窗口算法

相关推荐
niuTaylor2 小时前
从入门到精通:CMakeLists.txt 完全指南
linux·服务器·cmake
WaitWaitWait012 小时前
LeetCode每日一题4.20
算法·leetcode
蒟蒻小袁2 小时前
力扣面试150题--有效的括号和简化路径
算法·leetcode·面试
跳跳糖炒酸奶3 小时前
第十五讲、Isaaclab中在机器人上添加传感器
人工智能·python·算法·ubuntu·机器人
明月看潮生5 小时前
青少年编程与数学 02-018 C++数据结构与算法 06课题、树
数据结构·c++·算法·青少年编程·编程与数学
SuperW5 小时前
Linux学习——UDP
linux·学习·udp
小指纹5 小时前
动态规划(一)【背包】
c++·算法·动态规划
_安晓5 小时前
数据结构 -- 图的应用(一)
数据结构·算法·图论
阳洞洞5 小时前
leetcode 二分查找应用
算法·leetcode·二分查找
猎猎长风5 小时前
【数据结构和算法】1. 数据结构和算法简介、二分搜索
数据结构·算法