leecode 3. 无重复字符的最长子串
Posted hansc-blog
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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);
以上是关于leecode 3. 无重复字符的最长子串的主要内容,如果未能解决你的问题,请参考以下文章
Leecode03. 无重复字符的最长子串——Leecode大厂热题100道系列