LeetCode 第 3 题:无重复字符的最长子串(Python 代码)

简介: 这是一道没有多少知识点的题目,就是用滑动窗口的方式来写,算是一道挺简单的题目,但是想了我很久。我的方法和官方的题解是差不多的,但是写完之后看官方题解就感觉很好理解。

题目 3. 无重复字符的最长子串 的描述如下:给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。

子串 要求一定得是连续的,而 子序列 是可以不连续的。

这是一道没有多少知识点的题目,就是用 滑动窗口 的方式来写,算是一道挺简单的题目,但是想了我很久。我的方法和官方的题解是差不多的,但是写完之后看官方题解就感觉很好理解。先说一说我自己的写法,代码如下:

class Solution:
    def lengthOfLongestSubstring(self, s: str) -> int:
        n = len(s)
        if n < 2: return n  # 字符长度为 0 和 1 的时候直接返回 n
        ans = 1  # 子串最短也有 1
        i, j = 0, 0 # 左右指针
        cache = set(s[j])  # 哈希集合记录子串里的字符
        while j < n - 1 and i <= j:
            cache.add(s[j])
            if s[j+1] not in cache:  # 如果前面一个字符不存在
                j += 1  # 那么 j 往前一格把 s[j] 包含进去
                ans = max(ans, j - i + 1)  # 更新最长子串的长度
            else:  # 如果前面一个字符存在
                if i == j: j += 1  # 如果两个指针重合了,那么都要往前走
                cache.remove(s[i]) # 移除当前的左指针字符
                i += 1  # 左指针 i 往右一步
        return ans

滑动窗口(官方题解)

class Solution:
    def lengthOfLongestSubstring(self, s: str) -> int:
        cache = set()  # 哈希集合,记录每个字符是否出现过
        n = len(s)
        # 右指针,初始值为 -1,相当于我们在字符串的左边界的左侧,还没有开始移动
        rk, ans = -1, 0
        for i in range(n):
            if i != 0:
                cache.remove(s[i - 1])  # 左指针向右移动一格,移除一个字符
            while rk + 1 < n and s[rk + 1] not in cache:
                cache.add(s[rk + 1])  # 不断地移动右指针
                rk += 1
            # 第 i 到 rk 个字符是一个极长的无重复字符子串
            ans = max(ans, rk - i + 1)
        return ans

参考:LeetCode 官方题解

目录
相关文章
|
2月前
|
存储 算法 调度
【复现】【遗传算法】考虑储能和可再生能源消纳责任制的售电公司购售电策略(Python代码实现)
【复现】【遗传算法】考虑储能和可再生能源消纳责任制的售电公司购售电策略(Python代码实现)
181 26
|
1月前
|
测试技术 Python
Python装饰器:为你的代码施展“魔法”
Python装饰器:为你的代码施展“魔法”
233 100
|
1月前
|
开发者 Python
Python列表推导式:一行代码的艺术与力量
Python列表推导式:一行代码的艺术与力量
356 95
|
2月前
|
Python
Python的简洁之道:5个让代码更优雅的技巧
Python的简洁之道:5个让代码更优雅的技巧
231 104
|
2月前
|
开发者 Python
Python神技:用列表推导式让你的代码更优雅
Python神技:用列表推导式让你的代码更优雅
428 99
|
1月前
|
缓存 Python
Python装饰器:为你的代码施展“魔法
Python装饰器:为你的代码施展“魔法
152 88
|
1月前
|
监控 机器人 编译器
如何将python代码打包成exe文件---PyInstaller打包之神
PyInstaller可将Python程序打包为独立可执行文件,无需用户安装Python环境。它自动分析代码依赖,整合解释器、库及资源,支持一键生成exe,方便分发。使用pip安装后,通过简单命令即可完成打包,适合各类项目部署。
|
2月前
|
设计模式 人工智能 API
AI智能体开发实战:17种核心架构模式详解与Python代码实现
本文系统解析17种智能体架构设计模式,涵盖多智能体协作、思维树、反思优化与工具调用等核心范式,结合LangChain与LangGraph实现代码工作流,并通过真实案例验证效果,助力构建高效AI系统。
416 7
|
2月前
|
存储 大数据 Unix
Python生成器 vs 迭代器:从内存到代码的深度解析
在Python中,处理大数据或无限序列时,迭代器与生成器可避免内存溢出。迭代器通过`__iter__`和`__next__`手动实现,控制灵活;生成器用`yield`自动实现,代码简洁、内存高效。生成器适合大文件读取、惰性计算等场景,是性能优化的关键工具。
229 2
|
2月前
|
JSON 缓存 开发者
淘宝商品详情接口(item_get)企业级全解析:参数配置、签名机制与 Python 代码实战
本文详解淘宝开放平台taobao.item_get接口对接全流程,涵盖参数配置、MD5签名生成、Python企业级代码实现及高频问题排查,提供可落地的实战方案,助你高效稳定获取商品数据。

热门文章

最新文章

推荐镜像

更多
下一篇
oss云网关配置