给定一个字符串,找出不含有重复字符的最长子串的长度。
示例:
给定 "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);
原文:https://www.cnblogs.com/hansc-blog/p/9363296.html