Leetcode第三题(无重复字符的最长子串)

简介: 这篇文章介绍了解决LeetCode第三题“无重复字符的最长子串”的算法,使用滑动窗口技术来找出给定字符串中最长的不含重复字符的子串,并提供了详细的代码实现和解释。

题目描述:

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

示例 1:

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

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

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

class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        //创建一个数组存放字符的下标
        vector<int> pos(128,-1);
        int ans = 0;
        for(int i = 0,j = 0; i < s.length(); i++){
            //更新左边界
            j = max(j, pos[s[i]] + 1);
            //更新子串长度
            ans = max(ans, i - j + 1);
            pos[s[i]] = i;
        }
        return ans;
    }
};

创建一个数组用来存储字符的下标,ans用来存储最长子串的长度。i 表示子串的右边界,j表示子串的左边界

第一次循环:

    i = 0,j = 0; 更新左边界  j = max(0,0) 更新子串长度 ans = max(0,1)

   然后将pos\['a'\] = 0;

第二次循环:

    i = 1,j = 0; 更新左边界  j = max(0,0) 更新子串长度 ans = max(1,2)

   然后将pos\['b'\] = 1;

第三次循环:

    i = 2,j = 0; 更新左边界  j = max(0,0) 更新子串长度 ans = max(2,3)

   然后将pos\['c'\] = 2;

第四次循环:

    i = 3,j = 0; 更新左边界  j = max(0,0) 更新子串长度 ans = max(3,4)

   然后将pos\['d'\] = 3;

第五次循环:

    i = 4,j = 0; 更新左边界  j = max(0,2) 更新子串长度 ans = max(4,3)

   然后将pos\['b'\] = 4;

第六次循环:

    i = 5,j = 0; 更新左边界  j = max(2,1) 更新子串长度 ans = max(4,4)

   然后将pos\['a'\] = 5;

第七次循环:

    i = 6,j = 0; 更新左边界  j = max(2,0) 更新子串长度 ans = max(4,5)

   然后将pos\['e'\] = 6;

第八次循环

    i = 7,j = 0; 更新左边界  j = max(2,3) 更新子串长度 ans = max(5,5)

   然后将pos\['c'\] = 7;

故循环结束后ans = 5

相关文章
|
5月前
|
存储 算法 程序员
【Leetcode 程序员面试金典 01.01】判定字符是否唯一 —— 位运算|哈希表
可以使用哈希表或位运算来解决此问题:由题可知s[i]仅包含小写字母,int[26]即能表示字符的出现次数;
|
2月前
|
算法
LeetCode第3题无重复字符的最长子串
该文章介绍了 LeetCode 第 3 题无重复字符的最长子串的解法,通过使用 HashSet 记录不重复的子元素,以每个字符开头遍历字符串,遇到重复字符则重新计算,最终找到最长子串,同时提到可以考虑使用 HashMap 降低复杂度。
LeetCode第3题无重复字符的最长子串
|
4月前
|
存储 算法 数据可视化
深入解析力扣161题:相隔为 1 的编辑距离(逐字符比较与动态规划详解)
深入解析力扣161题:相隔为 1 的编辑距离(逐字符比较与动态规划详解)
|
4月前
|
存储 算法 数据可视化
深入解析力扣157题:用Read4高效读取N个字符(多种解法与详细图解)
深入解析力扣157题:用Read4高效读取N个字符(多种解法与详细图解)
|
3月前
|
索引
821.字符的最短距离-力扣(LeetCode)
821.字符的最短距离-力扣(LeetCode)
25 0
|
4月前
|
存储 算法 程序员
力扣经典150题第三十一题:无重复字符的最长子串
力扣经典150题第三十一题:无重复字符的最长子串
27 0
|
4月前
【LeetCode刷题】滑动窗口思想解决问题:长度最小的子数组、无重复字符的最长子串
【LeetCode刷题】滑动窗口思想解决问题:长度最小的子数组、无重复字符的最长子串
|
4月前
|
存储 算法 数据可视化
深入解析力扣159题:至多包含两个不同字符的最长子串(滑动窗口法详细图解)
深入解析力扣159题:至多包含两个不同字符的最长子串(滑动窗口法详细图解)
|
4月前
|
存储 算法 数据挖掘
LeetCode 第三题:无重复字符的最长子串 详解 【3/1000】
LeetCode 第三题:无重复字符的最长子串 详解 【3/1000】
|
5月前
|
机器学习/深度学习 索引
【力扣】387. 字符串中的第一个唯一字符
【力扣】387. 字符串中的第一个唯一字符