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

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

  • 题目
  • 解题思路
    • 思路及算法
    • 代码

题目

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

示例 1:

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

示例 2:

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

示例 3:

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

提示:

0 <= s.length <= 5 * 104
s 由英文字母、数字、符号和空格组成

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/longest-substring-without-repeating-characters
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路

思路及算法

  1. LeetCode官方详细解答
  2. 算法流程(滑动窗口)
    2.1 依次遍历字符串中的每个字符
    2.2 对于每个字符,我们需要遍历后面剩余的字符,直到出现重复字符为止,记录此时的子字符串长度
    2.3 当搜索完当前起始位置字符后,当前字符可不用再次遍历,我们可以将其删除即可;
    2.4 对于末端的位置,当遍历新的起始位置字符时,我们可以在其基础位置上继续像右移动即可;

举例如下:

str = "abcabcbb"
1. (a)bcabcbb -> (ab)cabcbb -> (abc)abcbb
2. (b)cabcbb -> (bc)abcbb -> (bca)bcbb
3. (c)abcbb -> (ca)bcbb -> (cab)cbb
4. (a)bcbb -> (ab)cbb -> (abc)bb
5. (b)cbb -> (bc)bb
6. (c)bb -> (cb)b
7. (b)b -> (b)b
8.  b -> b
  1. 针对上面的流程,我们需要3个模块,一是删除模块,二是首位值与无重复子串的结束位置表示,三是判断字符是否重复的模块;基于此,我们可以选择哈希集合来作为数据结构。

代码

#include 
#include 
using namespace std;

class Solution {
public:
    int lengthOfLongestSubstring(string str) {
        //1.创建一个哈希集合,用于存储字符,并判断字符是否存在
        unordered_set<char> occ;
        int n = str.size(); //计算字符长度
        int rk = -1; //定义末端位置指针,即右指针,用来移动右端字符位置
        int ans = 0; //记录最长子串的长度

        //2.对字符进行遍历
        for (int i = 0; i < n; ++i) {
            if (i != 0) {
                occ.erase(str[i - 1]); //删除已经遍历过的起始端字符
            }
            //int count = occ.count(str[rk + 1]);  //判断是否存在重复字符
            while (rk + 1 < n && !occ.count(str[rk + 1])) {    //判断右端的指针是否超出字符,并且右边无重复字符
                occ.insert(str[rk + 1]); //将不重复的字符插入哈希集合中
                ++rk;
            }
            ans = max(ans, rk - i + 1);  //保存最大子串长度
        }

        return ans;
    }
};

int main()
{
    Solution solution;
    string str = "abcdefgab";
    int maxLength = solution.lengthOfLongestSubstring(str);
}

你可能感兴趣的:(数据结构与算法,leetcode,算法,c++)