温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

python怎么找出无重复字符的最长子串

发布时间:2022-03-22 16:28:25 来源:亿速云 阅读:260 作者:iii 栏目:大数据

这篇文章主要介绍“python怎么找出无重复字符的最长子串”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python怎么找出无重复字符的最长子串”文章能帮助大家解决问题。

【题目】

给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。

示例 1:
输入: "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
    
示例 2:
输入: "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
    
示例 3:
输入: "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
     请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

【思路】

1、暴力破解:两层for循环,遍历所有子串,判断是否有重复元素,并记录最长子串长度。

2、hash表:遍历数组,使用hash存储元素及其下标。遍历时,当元素nums[i]存在于hash表时,需要更新其下标,同时更新最长子串长度。

【代码】

python版本

class Solution:
    def lengthOfLongestSubstring(self, s: str) -> int:
        d = {}
        last_index = 0
        res = 0
        for i, si in enumerate(s):
            # 在dict中,则子串长度可能更长
            # last_index更新为d[si] + 1
            if si in d and d[si] >= last_index:
                res = max(res, i - last_index)
                last_index = d[si] + 1
            
            # 更新dict的si
            d[si] = i
            
        # 注意,还未和最后一段进行比较
        res = max(res, len(s) - last_index)
        return res

关于“python怎么找出无重复字符的最长子串”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI