leecode 3. 无重复字符的最长子串
给定一个字符串,找出不含有重复字符的最长子串的长度。
示例:
给定"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);优质内容筛选与推荐>>