题目描述
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
示例 1:
输入: "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:
输入: "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
示例 3:
输入: "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
个人理解
首先这道题目题解主要用了滑动窗口法。这个在官方题解中讲的很详细,我贴下地址:
我参考的是 gradyang 大佬的解答。但我认为自己理解很有问题。所以,只简单说一下;
处理思路:
- 左边界:每次更新左边界值,要已有左边界和本次字母的索引值进行对比,要二者中的大的那个值更新左边界;
- 索引:每个字符的索引值就是他在字符串中的下标;
- 子串长度:已有子串长度和本次窗口长度的大值。
处理细节:
- 初始化为 -1 解决长度差的问题。
代码
class Solution {
public:
int lengthOfLongestSubstring(string s) {
if (s.length() == 0) return 0;
if (s.length() == 1) return 1;
int len = 0; // 结果
int left = -1; // 左边界
vector<int> index(128, -1); // 索引
for (int j = 0; j < s.length(); j++) {
left = max(left, index[s[j]]);
index[s[j]] = j;
len = max(len, j - left);
}
return len;
}
};
参考
题解来自大佬 grandyang
https://www.cnblogs.com/grandyang/p/4480780.html (ps:内有多种解法。)