题目
- 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度
解答
/**
* 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度
*
* @param str
*/
private static int getMaxLength(String str) {
if (str == null || str.length() == 0) return 0;
int length = 0;
int left = 0;
HashMap<Character, Integer> map = new HashMap<>();
for (int i = 0; i < str.length(); i++) {
// map中包含重复字符串,更新left位置,index从0开始
if (map.containsKey(str.charAt(i))) {
left = Math.max(left, map.get(str.charAt(i))+1);
}
// 将字符作为键
map.put(str.charAt(i), i);
// 更新长度
length = Math.max(length, i - left + 1);
}
return length;
}