剑指offer 最长不含重复字符的子字符串

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

描述:
请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。

题解:
维护一个map用来存放遍历到的字符以及下标
maxlen用来存放最大的长度值
curlen用来存放现在正在遍历的不重复字符串的长度
存在三种情况:

  • 当前字符没有出现过,也就是map中没有这个字符的信息,此时curlen++
  • 当前字符减去上一次该字符出现的下标大于curlen,说明该字符上一次字符出现的时候在上一个计算的不重复字符串中,也就是这一个字符并没有重复,curlen++
  • 当前字符在这次不重复字符串的计算中已经出现过,说明已经出现重复了,curlen=i-index
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param s string字符串 
     * @return int整型
     */
    int lengthOfLongestSubstring(string s) {
        // write code here
        map<char, int> index;
        int maxlen=0,curlen=0;
        for(int i=0;i<s.length();i++){
            if(index.find(s[i])==index.end()){
                curlen++;
            }else if(i-index[s[i]]>curlen){
                curlen++;
            }else{
                curlen=i-index[s[i]];
            }
            if(curlen>maxlen){
                maxlen=curlen;
            }
            //如果没有出现过就是向index中添加元素,出现过就是更新index值
            index[s[i]]=i;
        }
        return maxlen;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值