【leetcode算法-中等】3. 无重复字符的最长字串

【题目描述】

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

示例 1:

输入: "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:

输入: "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
示例 3:

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

解答

  • 解法:滑动窗口法

    利用set中没有重复元素来求解

滑动窗口在本题可以理解为 我们取了s中的一个字串 s[i, j], j 不断向后遍历,如果遇到 s[j] 不在set里,就将 s[j]加入set,并更新 当前无重复字符的字符串 的长度result

    若是 s[j] 与set中某个元素相同,就从子串的左边开始删除,一直到那个相同的元素删掉了为止

     例:s = ‘abcbc‘

    在set = (‘a‘, ‘b‘, ‘c‘)时很好理解,就是执行了三次while循环,且执行的都是if语句,此时 i = 0,j = 3, result = 3

    第四次循环:s[j] = ‘b‘,这个元素已经存在于集合中了,执行else语句,将 s[i] 从set中删除,set = (‘b‘, ‘c‘),i = 1

    第五次循环:s[j] = ‘b‘ , 仍然在set中,那么继续执行else语句,将s[i]从set中删除,set = (‘c‘) ,i = 2

    第六次循环:s[j] = ‘b‘ , 不在set中,执行 if 语句,将s[j]加入到set中 ,j = 4,set = (‘c‘, ‘b‘), result = max(result, j-i) = 3

    这个滑动窗口就找到了s中所有不含重复字符的字串,并且每一次都更新result的值,直到 j 遍历完整个字符串长度

class Solution:
    def lengthOfLongestSubstring(self, s: str) -> int:
        strSet = set() #定义一个空集合,存储 没有重复字符的字符串 里的元素
        result = 0
        i,j = 0,0
        n = len(s)
        while j < n:
            if s[j] not in strSet: #如果s[j]不在这个集合中
                strSet.add(s[j])  #将这个元素加入到集合
                j += 1
                result = max(result,j-i)
            else:
                strSet.remove(s[i])  #否则从左边开始删除,直到把重复的那个字符删掉为止
                i += 1
        return result

  执行用时 :72 ms, 在所有 python3 提交中击败了73.59%的用户

  内存消耗 :12.8 MB, 在所有 python3 提交中击败了99.66%的用户

原文地址:https://www.cnblogs.com/xxx1206/p/12077974.html

时间: 2024-10-08 12:05:39

【leetcode算法-中等】3. 无重复字符的最长字串的相关文章

leetcode无重复字符的最长字串 python实现

无重复字符的最长字串是一道字符串处理算法的题目,在日常编程中,处理字符串是常见任务.用Python来实现leetcode这道算法题,该题目会涉及到一个概念"滑动窗口". 一.题目描述 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度(Longest substring without repeating characters). 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所

无重复字符的最长字串问题

leetcode3:无重复字符的最长字串问题 问题描述 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb"输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3.示例 2: 输入: "bbbbb"输出: 1解释: 因为无重复字符的最长子串是 "b",所以其长度为 1.示例 3: 输入: "pwwkew"输出: 3 这道题,我自己的

编程练习:无重复字符的最长字串

题目LeetCode-无重复字符的最长字串 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例1 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3. 示例2 输入: "bbbbb" 输出: 1 解释: 因为无重复字符的最长子串是 "b",所以其长度为 1. 分析与实现 解法一 分析 这里面的难度在于,从i开始遍历,遇到相同字符后结束,记录长度.然后从

无重复字符的最长字串

题目描述: 给定一个字符串,找出不含有重复字符的最长子串的长度. 示例: 给定 "abcabcbb" ,没有重复字符的最长子串是 "abc" ,那么长度就是3. 给定 "bbbbb" ,最长的子串就是 "b" ,长度是1. 给定 "pwwkew" ,最长子串是 "wke" ,长度是3.请注意答案必须是一个子串,"pwke" 是 子序列 而不是子串 思路: 假设字符串为

[leetcode]3无重复字符的最长字串

本题思路较清楚,通过一个数组记录各个位置所能够引导的最长字符串的长度即可. 稍微有一点难度在于如何向前寻找时判断已经出现了重复字符串,我采用的思路为只有当前项的长度等于当前长度时,认为尚未出现重复字符串,并更新前项长度++. 1 int max=0; 2 int st[100000]={0};//表示以它为开头的最长不重复字串长度 3 int i=0; 4 char p; 5 while(s[i]!='\0') 6 { 7 p=s[i]; 8 st[i]=1; 9 max=st[i]; 10 f

Leetcode(3)无重复字符的最长子串

Leetcode(3)无重复字符的最长子串 [题目表述]: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 第一种方法:暴力 执行用时:996 ms: 内存消耗:12.9MB 效果:太差 class Solution(object): def lengthOfLongestSubstring(self, s): """ :type s: str :rtype: int """ Maxsize=0 res='' if len(s)

BAT面试算法进阶(2)- 无重复字符的最长子串(暴力法)

一.算法题 题目 Given a string, find the length of the longest substring without repeating characters. Example Given "abcabcbb", the answer is "abc", which the length is 3. Given "bbbbb", the answer is "b", with the length

LeetCode 第3题 无重复字符的最长子串

/*3. 无重复字符的最长子串给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb"输出: 3解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3. 示例 2: 输入: "bbbbb"输出: 1解释: 因为无重复字符的最长子串是 "b",所以其长度为 1. 示例 3: 输入: "pwwkew"输出: 3解释: 因为无重复字符的最长子串是 &qu

【leetcode】 算法题3 无重复字符的最长子串

问题 给定一个字符串,找出不含有重复字符的最长子串的长度. 示例: 给定 "abcabcbb" ,没有重复字符的最长子串是 "abc" ,那么长度就是3. 给定 "bbbbb" ,最长的子串就是 "b" ,长度是1. 给定 "pwwkew" ,最长子串是 "wke" ,长度是3.请注意答案必须是一个子串,"pwke" 是 子序列  而不是子串 代码实现 class S