题目描述:
给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
示例 1:
输入: s = "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:
输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
示例 3:
输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
示例 4:
输入: s = ""
输出: 0
提示:
0 <= s.length <= 5 * 104
s 由英文字母、数字、符号和空格组成
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解法思路:
利用滑动窗口思想,从头开始遍历字符串,遍历所有无重复子串,然后得到最大的长度。
时间复杂度:O(n);
空间复杂度:O(m);
举例:
输入: s = "pwwkew"
对字符串遍历,从下标k=0开始,当k为2的时候则出现重复字符,此时下标k移动到2,最大不重复长度为2。然后k继续向后移动,当k为5的时候出现重复字符,此时最大不重复长度为5-2
具体代码如下:
public static int lengthOfLongestSubstring(String s) {
List<Character> occ = new ArrayList<>();
int n = s.length();
int rk = -1;
int ans = 0;
for (int i = 0; i < n+1; i++) {
if (i != 0) {
occ.remove(Character.valueOf(s.charAt(i-1)));
}
while (rk + 1 < n && !occ.contains(s.charAt(rk + 1))) {
occ.add(s.charAt(rk+1));
rk = rk + 1;
}
ans = Math.max(ans, rk-i+1);
}
return ans;
}