3. 无重复字符的最长子串
lengthOfLongestSubstring

一、解题思路
1、解法一( Java )
解法思路:滑动窗口
- 使用 两个指针
left以及right表示字符串中的某个子串(或窗口)的左右边界 - 在每一步的操作中,我们会将左指针向右移动一格,表示 我们开始枚举下一个字符作为起始位置,然后我们可以不断地向右移动右指针,但需要保证这两个指针对应的子串中没有重复的字符。在移动结束后,这个子串就对应着 以左指针开始的,不包含重复字符的最长子串。
伪代码如下:
/**
* @author Listen 1024
* @description
* @date 2022-03-29 15:27
*/
class Solution15 {
public int lengthOfLongestSubstring(String s) {
//sliding window
// 哈希集合,记录每个字符是否出现过
Set<Character> set = new HashSet<Character>();
int len = s.length();
int res = 0;
//left pointer & right pointer
// 右指针,初始值为 -1,相当于我们在字符串的左边界的左侧,还没有开始移动
int right = -1;
for (int left = 0; left < len; left++) {
if (left != 0) {
// 左指针向右移动一格时,移除一个字符
set.remove(s.charAt(left - 1));
}
while (right + 1 < len && !set.contains(s.charAt(right + 1))) {
// 不断地移动右指针
set.add(s.charAt(right + 1));
right++;
}
// 第 i 到 rk 个字符是一个极长的无重复字符子串
res = Math.max(res, right - left + 1);
}
return res;
}
}

运行结果截图如下:


本文介绍了一种利用滑动窗口解决无重复字符最长子串问题的方法。通过使用哈希集合跟踪字符出现状态,实现对字符串的有效遍历,找到最长的无重复字符子串。
906

被折叠的 条评论
为什么被折叠?



