题解 | #最长不含重复字符的子字符串#

最长不含重复字符的子字符串

http://www.nowcoder.com/practice/48d2ff79b8564c40a50fa79f9d5fa9c7

动态规划+哈希表,看到很多题解都用了数组来保存当前为结尾的最长结果,其实可以更加优化。当出现重复字符时,只需要更新最近的相同字符作为长度计算起点,然后每次更新最长不同字符字串长度值即可

        int start = -1, sub = 1;
        //哈希表存储字符和字符位置的对应关系
        HashMap<Character,Integer> chara = new HashMap<Character,Integer>();
        //遍历字符串
        for(int i = 0;i < s.length();i++){
            if(chara.containsKey(s.charAt(i))){
                //更新最近的相同字符作为长度计算起点
                start = Math.max(start,chara.get(s.charAt(i)));
            }
            chara.put(s.charAt(i),i);
            //更新最长不同字符字串长度值
            sub = Math.max(sub,i - start);
        }
        return sub;
    
全部评论

相关推荐

牛客618272644号:佬携程工作怎么样,强度大吗
点赞 评论 收藏
分享
10-30 10:16
南京大学 Java
龚至诚:给南大✌️跪了
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-21 17:16
科大讯飞 算法工程师 28.0k*14.0, 百分之三十是绩效,惯例只发0.9
点赞 评论 收藏
分享
12 1 评论
分享
牛客网
牛客企业服务