简单编程题目连载(十四)——最长无重复字符子串

经典的字符串问题,并且结合了动态规划解题思想。

题目:给定一个字符串str,返回str的最长无重复字符子串长度

举个例子,str=“aabcb”其最长无重复子串的长度为3。

如何找到最长无重复子串,首先定义一个HashMap:hm,hm的意义在于保存当前字符上一个的位置,比如遍历到最后一个字符b,那么hm.get(‘b’)=2,遍历到第二个a,hm.get(‘a’)=0。再定义一个变量pre,pre的意义为代表以[i-1]结尾的字符串的最长无重复子串的长度,比如遍历到第二个a,那么pre=1,遍历到第二个b时,pre=3。最终定义max值为保存结果的值。

而整个遍历的过程为:重复遍历整个字符串,判断每个字符是否存在于哈希表中,如果不存在,则添加到哈希表,pre++。而当判断出当前字符已经存在于哈希表中,则需要更新max变量,max为pre和max中的较大值。接着更新pre变量,如果当前字符位置到上一次该字符出现位置的差值大于当前的pre值,那么pre++,如果小于pre值,则令pre=该差值。意义为pre一直表示着[i-1]的最长无重复子串长度。然后更新哈希表中的当前字符value值。然后重复整个过程,直到结束。

代码如下:

public int longestSubstring(String A){
    if(A == null){
        return 0;
    }
    char[] ch = A.toCharArray();
    HashMap<String,Integer> hm = new HashMap<String,Integer>();
    int pre = 0;
    int max = 0;
    for(int i = 0; i < ch.length; i++){
        if(hm.get(String.valueOf(ch[i])) == null){
            hm.put(String.valueOf(ch[i]),i);
            pre++;
        }else{
            max = Math.max(max,pre);
            pre = i - hm.get(String.valueOf(ch[i])) > pre ? pre+1 : i - hm.get(String.valueOf(ch[i]));
            hm.put(String.valueOf(ch[i]),i); 
        }
    }
    //用于判断最后一个子串是否比之前的大
    return Math.max(max,pre);
}

提供两个测试用例,大家可以断点试试程序。
str1=”kojypxtmcheuvhpkqapldlkxkdbbouclkqwpnivxquwimbexyuqlipqpnlaklsqjnhcqspegqswpwinmvaokwbzylyrctfiscjuweakmmiaqsuanrfxhaffeuaauafqkeksjxgdpspkzzzsawuyvrdbgdqhrnkspldkkqfmlsofadojwfdikwpzsafacxoktpxkzmzzihljiqlsnbygkstydeflbgjrzrtxryfcntduaadqyzxmsrrxqbgldcvmtmqwyqgjtda”; 返回13。

str2=”aabcd”;返回4。

str3=”aabcb”;返回3。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值