Python闯LeetCode--第3题:无重复字符的最长子串

Problem: 3. 无重复字符的最长子串

文章目录

思路

一上来马上想到两层for循环暴力枚举,但是又立马想到复杂度是 O ( n 2 ) O(n^2) O(n2),思考了一下能否有更优解,于是想到用头尾两个指针来指定滑动窗口(主要是python的字符串可作为字符列表来操作,用头尾两个指针的列表索引来提取子串很方便)

解题方法

1、首先考虑特殊情况,字符串长度为0或为1,则直接返回字符串长度num_char

2、设置一个变量max_son来记录最长子串长度

3、设立头尾两个指针i、j,初始值都为0,用来提取子串以滑动窗口

4、当j指向的下一个字符不在目前的子串中,即可以形成新的不重复子串,则j+1,且如果超过最大子串长度,则更新max_son的值

5、当j指向的下一个字符出现重复,则i+1,用新的头指针来遍历

6、直到j到达字符串末端,则停止

复杂度

时间复杂度:

O ( n ) O(n) O(n)

空间复杂度:

O ( n ) O(n) O(n)

Code

python 复制代码
class Solution:
    def lengthOfLongestSubstring(self, s: str) -> int:
        num_char = len(s)
        if num_char <= 1:
            return num_char
        max_son = 1
        i, j = 0, 0
        while j < num_char-1:
            str_son = s[i:j+1]
            if s[j+1] not in str_son:
                if len(str_son)+1 > max_son:
                    max_son = len(str_son)+1
                j += 1
            else:
                i += 1
                j = i
        return max_son
相关推荐
gc_2299几秒前
学习Python中Selenium模块的基本用法(19:操作下拉框)
python·selenium
·白小白1 分钟前
力扣(LeetCode) ——118.杨辉三角(C++)
c++·算法·leetcode
我的xiaodoujiao10 分钟前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 19--测试框架Pytest基础 3--前后置操作应用
python·学习·测试工具·pytest
std787914 分钟前
Rust 与 Go – 比较以及每个如何满足您的需求
开发语言·golang·rust
计算衎19 分钟前
基于Python实现CANoe和UDE交互通信工具实现,CAPL脚本通过python交互工具与UDE进行通信和调用UDE的组件获取UDE返回值。
python·capl·canoe·ude·nm_oncan
报错小能手20 分钟前
python(入门)map内置函数及import模块导入,as别名
开发语言·人工智能·python
梵得儿SHI27 分钟前
Java 反射机制实战:对象属性复制与私有方法调用全解析
java·开发语言·java反射机制的实际应用·对象属性复制·反射调用私有方法·私有字段·类型兼容性和敏感字段忽略
sulikey30 分钟前
C++的STL:深入理解 C++ 的 std::initializer_list
开发语言·c++·stl·list·initializerlist·c++标准库
仰泳的熊猫39 分钟前
LeetCode:207. 课程表
数据结构·c++·算法·leetcode