首页 > 代码库 > 字符串练习(八):最长无重复字符子串
字符串练习(八):最长无重复字符子串
对于一个字符串,请设计一个高效算法,找到字符串的最长无重复字符的子串长度。
给定一个字符串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; }}
字符串练习(八):最长无重复字符子串
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。