Python3 无重复字符的最长子串的实现
作者:Joy_917 时间:2021-12-09 21:36:24
题目:
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
示例:
示例 1:
输入: “abcabcbb”
输出: 3
解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。
示例 2:
输入: “bbbbb”
输出: 1
解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。
示例 3:
输入: “pwwkew”
输出: 3
解释: 因为无重复字符的最长子串是 “wke”,所以其长度为 3。
请注意,你的答案必须是 子串 的长度,“pwke” 是一个子序列,不是子串。
思路:
这道题会很自然的想到暴力解法,就是按位递增依次检查子串是否重复,并记下目前最大的子串长度,如果重复就从下一位索引处的字符开始重新检查。下面是代码实现:
class Solution:
def lengthOfLongestSubstring(self, s: str) -> int:
# 最长子串的长度
max_len = 0
# 存放字符的字典
char_dict = {}
index = 0
while s[index:].__len__() >= max_len:
# 当前最长子串长度
current_len = 0
for item in s[index:]:
old_index = char_dict.get(item)
if old_index is not None:
index = old_index + 1
char_dict.clear()
break
char_dict[item] = index
index += 1
current_len += 1
if current_len > max_len:
max_len = current_len
return max_len
开始只是想跑通,没想到超出了时间限制。看起来代码显得是有点啰嗦,但是思路应该是没有问题的,我们还是从遍历的角度来优化。
优化:
在上面的代码中,当遇到重复字符时,遍历的起始点就往后挪一位,但其实两个重复字符之间的部分是不会重复的,比如字符串fbacdadfeed,在第一次从 f 开始遍历遇到重复字符即第二个 a 的时候,下一次遍历不应该从 b 开始,而是应该从前一个重复字符的后一个字符即 c 开始。
确定思想,并多次优化后的代码如下:
class Solution:
def lengthOfLongestSubstring(self, s: str) -> int:
char_dict = {}
start, end, max_len = -1, 0, 0
str_len = s.__len__()
while end < str_len:
char = s[end]
if char in char_dict:
old_index = char_dict[char]
if old_index > start:
start = old_index
diff = end -start
if diff > max_len:
max_len = diff
char_dict[char] = end
end += 1
return max_len;
这里使用了内置的.__len__()方法来获取字符串长度而不是len(),并且使用了多个看似多此一举的临时变量来存储值,比如char和diff,都是为了节省时间,蚊子小也是肉嘛。
结果也是 ok 的:
来源:https://blog.csdn.net/qq_35221523/article/details/88958973
标签:Python3,无重复字符,最长子串
0
投稿
猜你喜欢
如何使用flask将模型部署为服务
2021-11-11 06:02:48
js控制文本框禁止输入特殊字符详解
2024-04-25 13:07:03
MySQL通配符与正则表达式搜过滤数据详解
2024-01-23 03:12:54
JavaScript中Promise处理异步的并行与串行
2024-04-28 09:47:12
php中$_GET与$_POST过滤sql注入的方法
2023-07-13 14:38:12
Python OpenCV Hough直线检测算法的原理实现
2021-01-29 10:10:00
解决django 新增加用户信息出现错误的问题
2021-07-27 12:50:46
Python实现读取txt文件并画三维图简单代码示例
2023-06-11 15:44:18
Python实现的简单万年历例子分享
2021-01-09 14:56:54
用css制作星级投票评分功能
2008-01-08 21:12:00
python获取一组汉字拼音首字母的方法
2023-04-08 16:43:02
Oracle动态交叉表生成
2010-07-27 12:55:00
MySQL8.0+版本1045错误的问题及解决办法
2024-01-16 23:19:33
tensorboard显示空白的解决
2023-05-28 15:05:05
Python+eval函数实现动态地计算数学表达式详解
2023-08-13 22:39:11
python通过colorama模块在控制台输出彩色文字的方法
2023-07-23 00:35:51
Thinkphp5.0 框架的请求方式与响应方式分析
2023-11-15 00:07:09
MySQL的常用命令集锦
2024-01-16 00:40:44
MySQL 表数据的导入导出操作示例
2024-01-18 17:20:19
Python实现常见的4种坐标互相转换
2023-11-21 06:22:38