LeetCode 算法 3.无重复字符的最长子串(python版)

1.需求

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

#输入: s = "pwwkew"

#输出: 3

#解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。

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

2.代码

python 复制代码
class Solution:
    def length_substring(self, str):
        # 如果字符串为空,直接返回0
        if not str:
            return 0
        # 定义一个变量,用来指向字符串最左边的元素,用于删除
        left = 0
        # 定义一个集合,用于存储子字符串(集合中不允许有重复值)
        str_child = set()
        # 获取当前字符串长度
        n = len(str)
        # 定义子串的最大长度
        max_len = 0
        # 定义当前遍历长度
        cur_len = 0
        for i in range(n):
            cur_len += 1
            # 如果当前字符在子串集合中,移除当前子串的最左边的元素
            # 同时将指向最左边的变量+1,将当前长度变量-1
            while str[i] in str_child:
                str_child.remove(str[left])
                left += 1
                cur_len -= 1
            # 如果当前长度大于子串的最大长度,将最大长度=当前长度
            if cur_len > max_len:
                max_len = cur_len
            # 将遍历到的字符加入到子串集合中
            str_child.add(str[i])
        return max_len

if __name__ == '__main__':
    res=Solution()
    str='pwwkew'
    index=res.length_substring(str)
    print(index)

3.分析

python 复制代码
    # 解析:
    # 1. cur_len=1 -> p不在set()中 -> max_len=1 -> set(p)
    # 2. cur_len=2 -> w不在set(p)中 -> max_len=2 -> set(pw)
    # 3. cur_len=3 -> w在set(pw)中 -> set(w) -> left=1 -> cur_len=2
    # 4. cur_len=2 -> k不在set(w)中 -> set(wk)
    # 5. cur_len=3 -> e不在set(wk)中 -> max_len=3 -> set(wke)
    # 6. cur_len=4 -> w在set(wke)中 -> set(ke) -> left=1 -> cur_len=3
    # 7.循环结束 max_len=3

4.运行结果

相关推荐
懒惰才能让科技进步38 分钟前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝
yyfhq1 小时前
sdnet
python
Ni-Guvara1 小时前
函数对象笔记
c++·算法
测试19981 小时前
2024软件测试面试热点问题
自动化测试·软件测试·python·测试工具·面试·职场和发展·压力测试
love_and_hope1 小时前
Pytorch学习--神经网络--搭建小实战(手撕CIFAR 10 model structure)和 Sequential 的使用
人工智能·pytorch·python·深度学习·学习
泉崎1 小时前
11.7比赛总结
数据结构·算法
你好helloworld1 小时前
滑动窗口最大值
数据结构·算法·leetcode
海阔天空_20131 小时前
Python pyautogui库:自动化操作的强大工具
运维·开发语言·python·青少年编程·自动化
零意@2 小时前
ubuntu切换不同版本的python
windows·python·ubuntu
思忖小下2 小时前
Python基础学习_01
python