资讯专栏INFORMATION COLUMN

[Leetcode]Longest Substring Without Repeating Char

awesome23 / 3367人阅读

摘要:解题思路本题借助实现。如果字符未出现过,则字符,如果字符出现过,则维护上次出现的遍历的起始点。注意点每次都要更新字符的位置最后返回时,一定要考虑到从到字符串末尾都没有遇到重复字符的情况,所欲需要比较下和的大小。

Longest Substring Without Repeating Characters
Given a string, find the length of the longest substring without repeating characters.

Examples:

Given "abcabcbb", the answer is "abc", which the length is 3.

Given "bbbbb", the answer is "b", with the length of 1.

Given "pwwkew", the answer is "wke", with the length of 3. Note that the answer must be a substring, "pwke" is a subsequence and not a substring.

1.解题思路

本题借助HashMap实现。
1) 如果字符未出现过,则put(字符,index);
2) 如果字符出现过,则维护len=上次出现的index-遍历的起始点。
那问题就到了如何去定义遍历的起始点呢,我们当然可以从0开始,然后每次加1,但是通过下面的例子,我们很容易就发现这样会有很多情况冗余:
“abcdecf”
我们从index 0开始,到第二个字符c-index5,我们会发现已经存在,所以len,5-0=5;但如果我们之后index从1开始,我们会发现必然还会在index5这边停止,为了减少这种冗余,我们想到可以在一次重复后,将start置为重复元素Index+1,这里就是index3-d, 这样我们在碰到已经存在的字符时,就要再加上一个判断,看其上一次出现是否在start之前,如果在start之前,则不作考虑,直接Put进新的位置;如果是在start之后,则就表明确实遇到了重复点。
注意点:
1)每次都要更新字符的位置;
2)最后返回时,一定要考虑到从start到s.length(字符串末尾)都没有遇到重复字符的情况,所欲需要比较下maxLen和s.length()-start的大小。

2.代码

public class Solution {
    public int lengthOfLongestSubstring(String s) {
        if(s.length()==0) return 0;
        HashMap hm=new HashMap();
        int start=0;
        int maxLen=1;
        for(int i=0;i=start){
                int len=i-start;
                maxLen=Math.max(maxLen,len);
                start=hm.get(s.charAt(i))+1;
            }
            hm.put(s.charAt(i),i);
        }
        return Math.max(maxLen,s.length()-start);
    }
}

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/69801.html

相关文章

  • LeetCode——Longest Substring Without Repeating Char

    摘要:原问题我的沙雕解法无重复字母存在重复字母挨打最暴力的无脑解法,耗时。。。 原问题 Given a string, find the length of the longest substring without repeating characters. Example 1: Input: abcabcbb Output: 3 Explanation: The answer is a...

    forsigner 评论0 收藏0
  • [LeetCode] Longest Substring Without Repeating Cha

    摘要:建立数组,存储个字符最近一次出现的位置。首次出现某字符时,其位置标记为,并用无重复字符计数器记录无重复字符的长度,再在更新其最大值。循环完整个字符串后,返回最大值。 Problem Given a string, find the length of the longest substring without repeating characters. Examples: Given ...

    CoderStudy 评论0 收藏0
  • leetcode 3 Longest Substring Without Repeating Cha

    摘要:题目详情题目要求输入一个字符串,我们要找出其中不含重复字符的最长子字符串,返回这个最长子字符串的长度。对于字符串中的每一个字符,先判断中是否已经存在这个字符,如果不存在,直接将添加到,如果已存在,则新的字符串就从不含前一个字符的地方开始。 题目详情 Given a string, find the length of the longest substring without repe...

    xcold 评论0 收藏0
  • [Leetcode] Longest Substring Without Repeating Cha

    摘要:哈希表是最自然的想法。在遍历字符串时,我们先根据哈希表找出该字符上次出现的位置,如果大于等于子字符串首,便更新子字符串首。结束后,将该字符新的位置放入哈希表中。 Longest Substring Without Repeating Characters 最新更新解法:https://yanjia.me/zh/2018/12/... Given a string, find the ...

    FleyX 评论0 收藏0
  • [LeetCode] Longest Substring Without Repeating Cha

    Problem Given a string, find the length of the longest substring without repeating characters. Examples Given abcabcbb, the answer is abc, which the length is 3. Given bbbbb, the answer is b, with the...

    graf 评论0 收藏0

发表评论

0条评论

awesome23

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<