给定一个字符串,找出不含有重复字符的最长子串的长度。
示例:
给定 "abcabcbb"
,没有重复字符的最长子串是 "abc"
,那么长度就是3。
给定 "bbbbb"
,最长的子串就是 "b"
,长度是1。
给定 "pwwkew"
,最长子串是 "wke"
,长度是3。请注意答案必须是一个子串,"pwke"
是 子序列 而不是子串。
String s = "abcbc"; int freq[] = new int[256];//最长没重复字符串最大长度 256 ,0 表示没有,1表示有 int l = 0 , r = -1; int len = 0 ; while(l < s.length()) { if(r + 1 < s.length() && freq[s.charAt(r + 1)] == 0 ) { freq[s.charAt(++r)] = 1; len = Math.max(len, r - l + 1); // 记录连续最大长度 } else { freq[s.charAt(l++)] = 0; } } System.out.println(len);