题目
给定一个字符串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
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。文章来源:https://www.toymoban.com/news/detail-498097.html
解题思路
思路及算法
- LeetCode官方详细解答
- 算法流程(滑动窗口)
2.1 依次遍历字符串中的每个字符
2.2 对于每个字符,我们需要遍历后面剩余的字符,直到出现重复字符为止,记录此时的子字符串长度
2.3 当搜索完当前起始位置字符后,当前字符可不用再次遍历,我们可以将其删除即可;
2.4 对于末端的位置,当遍历新的起始位置字符时,我们可以在其基础位置上继续像右移动即可;
举例如下:文章来源地址https://www.toymoban.com/news/detail-498097.html
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
- 针对上面的流程,我们需要3个模块,一是删除模块,二是首位值与无重复子串的结束位置表示,三是判断字符是否重复的模块;基于此,我们可以选择哈希集合来作为数据结构。
代码
#include <iostream>
#include <unordered_set>
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 刷题 3. 无重复字符的最长子串的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!