首页 > 代码库 > 字符串练习(八):最长无重复字符子串

字符串练习(八):最长无重复字符子串

对于一个字符串,请设计一个高效算法,找到字符串的最长无重复字符的子串长度。

给定一个字符串A及它的长度n,请返回它的最长无重复字符子串长度。保证A中字符全部为小写英文字符,且长度小于等于500。

测试样例:
"aabcb",5
返回:3
public class DistinctSubstring {    public int longestSubstring(String A, int n) {        // write code here        if(A==null || n==0){            return 0;        }        char[] chas=A.toCharArray();        int[] map=new int[256];//256个字符:记录每种字符之前出现的位置        for(int i=0;i<256;i++){            map[i]=-1;        }        int len=0;        int pre=-1;        int cur=0;//当前字符为止的最长无重复字符串的长度        for(int i=0;i<n;i++){            pre=Math.max(pre, map[chas[i]]);            cur=i-pre;            len=Math.max(len, cur);            map[chas[i]]=i;        }        return len;    }}

 

字符串练习(八):最长无重复字符子串