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.运行结果

相关推荐
智驱力人工智能33 分钟前
基于视觉分析的人脸联动使用手机检测系统 智能安全管理新突破 人脸与手机行为联动检测 多模态融合人脸与手机行为分析模型
算法·安全·目标检测·计算机视觉·智能手机·视觉检测·边缘计算
Mr_Xuhhh1 小时前
GUI自动化测试--自动化测试的意义和应用场景
python·集成测试
2301_764441331 小时前
水星热演化核幔耦合数值模拟
python·算法·数学建模
循环过三天1 小时前
3.4、Python-集合
开发语言·笔记·python·学习·算法
Q_Q5110082851 小时前
python+django/flask的眼科患者随访管理系统 AI智能模型
spring boot·python·django·flask·node.js·php
SunnyDays10113 小时前
如何使用Python高效转换Excel到HTML
python·excel转html
priority_key3 小时前
排序算法:堆排序、快速排序、归并排序
java·后端·算法·排序算法·归并排序·堆排序·快速排序
Q_Q5110082853 小时前
python+django/flask的在线学习系统的设计与实现 积分兑换礼物
spring boot·python·django·flask·node.js·php
不染尘.4 小时前
2025_11_7_刷题
开发语言·c++·vscode·算法
Q_Q5110082854 小时前
python+django/flask的车辆尾气检测排放系统-可视化大屏展示
spring boot·python·django·flask·node.js·php