给定一个字符串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
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
举例如下:
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
#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);
}