LintCode 384. 最长无重复字符的子串

384 最长无重复字符的子串

给定一个字符串,请找出其中无重复字符的最长子字符串。

样例
例如,在”abcabcbb”中,其无重复字符的最长子字符串是”abc”,其长度为 3。

对于,”bbbbb”,其无重复字符的最长子字符串为”b”,长度为1。

挑战
O(n) 时间
.

  • 如果要实现O(n) 时间,必须一次遍历字符串。
    用HashMap<字符,位置>储存每个字符的位置,用temp记录当前字符串长度。

    例如 “abcabcbb”

字符串Maptemp
a—-bcabcbb{a:0}1
ab—-cabcbb{a:0,b:1}2
abc—-abcbb{a:0,b:1,c:2}3
abca—-bcbb{a:3,b:1,c:2}3
abcab—-cbb{a:3,b:4,c:2}3
abcabc—-bb{a:3,b:4,c:5}3
abcabcb—-b{a:3,b:6,c:5}2
abcabcbb{a:3,b:7,c:5}1

-

i 是当前字符位置,i - temp是当前字符串起始位置。出现重复字符时,先判断字符上一次出现位置是否在当前字符串内,如果不在,则Map中更新位置并且temp++;如果在,则temp截断,从 上一次出现+1 的位置开始计算。

public class Solution {

    public int lengthOfLongestSubstring(String s) {

        Map<Character, Integer> pos = new HashMap<>();
        char[] ss = s.toCharArray();

        int max = 0, temp = 0;

        for(int i = 0; i < s.length(); i++){

            if( !pos.containsKey(ss[i]) ){
                pos.put(ss[i],i);
                temp++;
            }else{
                if(pos.get(ss[i]) + temp < i){
                    temp++;                
                }else{
                    max = Math.max(max,temp);
                    temp = i - pos.get(ss[i]);
                }
                pos.put(ss[i],i);
            }

        }
        max = Math.max(max,temp);
        return max;
    }
}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值