面试题:最长不含重复字符的子字符串

请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。假设字符串中只包含'a'~'z'的字符。例如,在字符串“arabcacfr”中,最长的不含重复字符的子字符串是“acfr”,长度为4。

思路:常规套路的话,先求有多少个子字符串,再看看是否有重复字符,那么一套下来就要O(n^3)。有点多,那么就用动态规划咯。

参考代码如下:

int longestSubstringWithoutDuplication(const std::string& str)

{

 int curLength=0;

int maxLength=0;

 int* position=new int[26] ;

for(int i=0;i<26;i++)

 position[i]=-1;

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

{

 int prevIndex=position[str[i]-'a'];

if(prevIndex<0||i-prevIndex>curLength)

 ++curLength;

  else

 {

 if(curLength>maxLength)

 maxLength=curLength;

   curLength=i-prevIndex;

}

position[str[i]-'a']=i;

}

if(curLength>maxLength)

 maxLength=curLength;

 delete[] position;

return maxLength;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值