leetCode/src/string/LengthOfLongestSubString.java

36 lines
903 B
Java

package string;
import java.util.HashSet;
import java.util.Set;
/**
* @apiNote 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
* 示例 1:
* 输入: "abcabcbb"
* 输出: 3
* 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
*
* @author zeekling
* @version 1.0
* @date 2020-04-07
*/
public class LengthOfLongestSubString{
public int lengthOfLongestSubstring(String s) {
int n = s.length();
Set<Character> set = new HashSet<>();
int ans = 0, i = 0, j = 0;
while (i < n && j < n) {
// try to extend the range [i, j]
if (!set.contains(s.charAt(j))){
set.add(s.charAt(j++));
ans = Math.max(ans, j - i);
}
else {
set.remove(s.charAt(i++));
}
}
return ans;
}
}