【滑动窗口】leetcode3:无重复字符的最长子串

这篇具有很好参考价值的文章主要介绍了【滑动窗口】leetcode3:无重复字符的最长子串。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一.题目描述

无重复字符的最长子串

【滑动窗口】leetcode3:无重复字符的最长子串,算法

 二.思路分析

题目要求我们找符合要求的最长子串,要求是不能包含重复字符

确定一个子串只需确定它的左右区间即可,于是我们可以两层循环暴力枚举所有的子串,找到符合要求的,并通过比较得到最长的长度。还有一个问题,怎么确定有没有重复字符呢?可以使用哈希表,如果把字符丢进哈希表后没有重复,那么right继续向后枚举,如果重复了直接退出循环,后面的不用枚举了,肯定也会重复。

class Solution {
public:
    int lengthOfLongestSubstring(string s) 
    {
        int n = s.size();
        int ret = 0;
        for (int left = 0; left < n; left++)
        {
            int hash[128] = {0};
            for (int right = left; right < n; right++)
            {
                int in = s[right];
                hash[in]++;
                if (hash[in] > 1)//出现重复的字符了
                {
                    break;
                }
                //没有出现重复字符
                ret = max(ret, right - left + 1);
            }
        }
        return ret;
    }
};

两层for循环,时间复杂度是O(n^2),leetcode上面不会超时能通过。但用暴力枚举太浪费这道题了,可以使用滑动窗口优化。

要想使用滑动窗口必须证明left和right都只会向前移动。

【滑动窗口】leetcode3:无重复字符的最长子串,算法

 left固定在第一个位置,right不断向后移动,移动过程中,如果没有出现重复字符则不断更新结果。当right移动到如图所示位置时,出现了重复字符,故left位置已经枚举完毕。

【滑动窗口】leetcode3:无重复字符的最长子串,算法

按照暴力枚举方法,left向前移动一步,right回退到left位置。但是最终right还是会走到原先标记的位置。因为经过上一轮枚举,[left - 1, tmp)区间内都是没有重复字符的,所以right会一直往前走。

【滑动窗口】leetcode3:无重复字符的最长子串,算法

所以right不必退回来,保持在原地不动,让left向右移动即可。我们发现此时区间内没有重复元素了,所以要更新结果,right继续向后移动。接下来的步骤就和前面的一样了。但是这里的left向后移动一步刚好就跳过了那个重复的元素,接下来我们看一个不一样的例子

【滑动窗口】leetcode3:无重复字符的最长子串,算法

 这里区间内出现重复元素,left向后移动一步

【滑动窗口】leetcode3:无重复字符的最长子串,算法

 但此时还是有重复元素,此时right也没有必要向后枚举了,因为肯定也是重复的。所以left还要继续向后移动,直到跳过重复的字符w,right才能被解放,继续向后移动。故left可能向后移动多步,这是一个循环的过程。

三.代码编写

【滑动窗口】leetcode3:无重复字符的最长子串,算法

 

 根据滑动窗口的代码模版,我们只需确定以上几个具体的步骤。那么什么时候更新结果呢?当我们找到符合要求的子串是就更新,什么时候是符合要求的呢?

当判断条件不成立

或者判断条件成立,但通过不断地出窗口,最终使判断条件不成立时是符合要求的。所以更新结果应该放在整个循环的最后。

class Solution {
public:
    int lengthOfLongestSubstring(string s) 
    {
        int n = s.size();
        int ret = 0;
        int hash[128] = {0};
        int left = 0, right = 0;
        while (right < n)
        {
            //进窗口
            int in = s[right];
            hash[in]++;

            //判断
            while (hash[in] > 1)
            {
                //出窗口
                int out = s[left];
                hash[out]--;
                left++;
            }

            //更新结果
            ret = max(ret, right - left + 1);
            
            right++;
        }
        return ret;
    }
};

时间复杂度O(n),效率大大提升文章来源地址https://www.toymoban.com/news/detail-679926.html

到了这里,关于【滑动窗口】leetcode3:无重复字符的最长子串的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 矩阵&滑动窗口|36. 有效的数独 3. 无重复字符的最长子串

    题目 :请你判断一个 9 x 9 的数独是否有效。只需要 根据以下规则 ,验证已经填入的数字是否有效即可。 数字 1-9 在每一行只能出现一次。 数字 1-9 在每一列只能出现一次。 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。(请参考示例图) 题目链接 :有效的数独

    2024年01月18日
    浏览(49)
  • 【滑动窗口】长度最小的子数组|无重复字符的最长子串|最大连续1的个数 III|将 x 减到 0 的最小操作数

    1. 长度最小的子数组 - 力扣(LeetCode) (1)方法一:暴力列举出所有的子数组的和 时间复杂度:O(n**2):枚举所有子数组O(n**2) (2)方法二: 利用 单调性(两个指针都不回退) ,使用\\\" 同向双指针 \\\"(其实就是 滑动窗口 )来优化 那么 滑动窗口过程 是怎么样的? 1le

    2024年03月22日
    浏览(54)
  • python - leetcode - 424. 替换后的最长重复字符【经典题解 - 贪心滑动窗口算法】

    描述: 给你一个字符串 s 和一个整数 k 。你可以选择字符串中的任一字符,并将其更改为任何其他大写英文字符。该操作最多可执行 k 次。 在执行上述操作后,返回包含相同字母的最长子字符串的长度。 示例 1: 示例 2: 提示: 1 = s.length = 105 s 仅由大写英文字母组成 0 =

    2024年02月16日
    浏览(47)
  • 【Leetcode】3. 无重复字符的最长子串

    给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 示例1: 示例2: 示例3: 提示 : 0 = s . l e

    2024年02月10日
    浏览(37)
  • LeetCode 3. 无重复字符的最长子串

    力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台 我们需要找的是含重复元素的最长子串,当然直接暴力求解固然简单。但是可能引发的情况是超时,而且面试官想看到的也不是让你去暴力解决这类问题。因此我们使用哈希+滑动窗口的思想来解决。 使用哈希表的缘故是更

    2024年02月09日
    浏览(41)
  • LeetCode 3 无重复字符的最长子串

    给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 示例 1: 示例 2: 示例 3: 提示: 0 = s.length = 5 * 104 s 由英文字母、数字、符号和空格组成 依次遍历字符串,如果这个字符在子串里,则把子串的这个字符之前的都删除,加新的字符,否则继续遍历即可。

    2024年02月07日
    浏览(36)
  • 【滑动窗口】1100. 长度为 K 的无重复字符子串

    给你一个字符串 S,找出所有长度为 K 且不含重复字符的子串,请你返回全部满足要求的子串的 数目。 示例 1: 输入:S = “havefunonleetcode”, K = 5 输出:6 解释: 这里有 6 个满足题意的子串,分别是:‘havef’,‘avefu’,‘vefun’,‘efuno’,‘etcod’,‘tcode’。 示例 2: 输入:

    2024年02月08日
    浏览(36)
  • LeetCode 刷题 3. 无重复字符的最长子串

    给定一个字符串s,找出其中不包含重复字符的最长子串。 示例 1: 示例 2: 示例 3: 提示: 来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/longest-substring-without-repeating-characters 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。 LeetCode官方详细解答

    2024年02月10日
    浏览(52)
  • 【LeetCode-中等题】3. 无重复字符的最长子串

    思路: 设置一个左指针,来判断下一个元素是否在set集合中,如果不在,就加入集合,right继续++,如果在,就剔除重复的元素,计算串的长度,在执行上述操作 代码:

    2024年02月11日
    浏览(38)
  • LeetCode-C#-0003.无重复字符的最长子串

    该题目来源于LeetCode 如有侵权,立马删除。 解法不唯一,如有新解法可一同讨论。 0003无重复字符的最长子串 给定一个字符串s,请你找出其中不含有重复字符的最长子串的长度。 示例 1: 输入: s = “abcabcbb” 输出: 3 解释: 因为无重复字符的最长子串是 “abc”,所以其长度为

    2024年02月08日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包