[LeetCode] 3. 无重复字符的最长子串

时间:2020-05-05 00:52:12   收藏:0   阅读:105

想到用滑动窗口来做了,没想到用hashmap来保存每一个位置。

public class L3 {
    public int lengthOfLongestSubstring(String s) {
        if(s.length()==0)return 0;
        HashMap<Character,Integer> map=new HashMap<>();
        int max=0;
        int left=0;
        for(int i=0;i<s.length();i++){
            if(map.containsKey(s.charAt(i))){
                left =Math.max(left,map.get(s.charAt(i))+1);
            }
            map.put(s.charAt(i),i);
            max=Math.max(max,(i-left+1));
        }
        return max;
    }
}

技术分享图片

 

原文:https://www.cnblogs.com/doyi111/p/12829023.html

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!