当前位置: 首页 > news >正文

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

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

文章目录

  • 思路
  • 解题方法
  • 复杂度
  • Code

思路

一上来马上想到两层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

class Solution:def lengthOfLongestSubstring(self, s: str) -> int:num_char = len(s)if num_char <= 1:return num_charmax_son = 1i, j = 0, 0while 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)+1j += 1else:i += 1j = ireturn max_son
http://www.lryc.cn/news/373747.html

相关文章:

  • HTML DOM 对象
  • 如何解决 BeautifulSoup 安装问题:从 BeautifulSoup 3 到 BeautifulSoup 4
  • 原型模式--深复制/浅复制
  • C# TextBox模糊查询及输入提示
  • Node入门以及express创建项目
  • Cheat Engine CE v7.5 安装教程(专注于游戏的修改器)
  • 【实例分享】访问后端服务超时,银河麒麟服务器操作系统分析及处理建议
  • Java中和的区别
  • 深入理解计算机系统 CSAPP 家庭作业6.34
  • [leetcode 141环形链表]双指针解决环形链表
  • 【深度学习】Precision、Accuracy的区别,精确率与准确率:深度学习多分类问题中的性能评估详解
  • DELL服务器插入新磁盘、创建虚拟磁盘、挂载磁盘步骤
  • springboot与flowable(10):网关服务(排他网关)
  • Web前端网页源代码:深入剖析与实用技巧
  • 聊天页面样式
  • PHP入门教程3:数组和字符串操作
  • mariadb
  • C/C++:指针用法详解
  • JDK8-17新特性
  • 文件加载的管理:探索三种方法
  • 【机器学习】基于Transformer架构的移动设备图像分类模型MobileViT
  • grub引导LinuxMint
  • Hadoop 2.0:主流开源云架构(四)
  • PythonSQL应用随笔4——PySpark创建SQL临时表
  • C# OpenCvSharp 矩阵计算-determinant、trace、eigen、calcCovarMatrix、solve
  • 知识普及:什么是边缘计算(Edge Computing)?
  • 大型企业IT基础架构和应用运维体系
  • 【源码】16国语言交易所源码/币币交易+期权交易+秒合约交易+永续合约+交割合约+新币申购+投资理财/手机端uniapp纯源码+PC纯源码+后端PHP
  • word空白页删除不了怎么办?
  • Java web应用性能分析之【prometheus+Grafana监控springboot服务和服务器监控】