zoukankan      html  css  js  c++  java
  • 3. 无重复字符的最长子串

    原题链接

    3. 无重复字符的最长子串

    解题思路

    • 在谈及重复问题,大概率会使用 hashmap 或者 hashset
    • 最长子串,因为是连续的,所以有点想使用滑动窗口的方法

    滑动窗口

    在 HashMap 中维护一个表,这个表的作用:

    • 记录每个字符最后一次出现的位置索引
    • HashMap 天然是无重复的

    以abcba举例,在检索到abc的时候,在hashmap中存入,a-0,b-1,c-2。

    当检索到3位置的b时,发现已经重复,所以直接放弃原来的b,滑动窗口的头,从b以前位置的下一个位置开始。

    同时将b-1更新为b-3,其中还有些小问题要注意:

    • 要用一个变量去记录最大长度
    • 以上面的为例,当我检测到a的时候,虽然a在hashmap中已经存在,但它其实已经不在滑动窗口的范围了,其实说明a在上一步,遇到b的时候,就已经被抛弃了。
    import java.util.HashMap;
    
    public class N3 {
        public static void main(String[] args) {
            String s = "abcabcbb";
            System.out.println(lengthOfLongestSubstring(s));
        }
    
        public static int lengthOfLongestSubstring(String s) {
            int left = 0;
            int max_len = 0;
            HashMap<Character, Integer> map = new HashMap<>();
            for (int i = 0; i < s.length(); i++) {
                if(map.containsKey(s.charAt(i)))
                    left = Math.max(left, map.get(s.charAt(i))+1);
                map.put(s.charAt(i), i);
                max_len = Math.max(max_len, i-left+1);
            }
            return max_len;
        }
    }
    
    
  • 相关阅读:
    降低大气分
    99999
    88888
    77777
    HandlerThread实现原理
    Android 内存泄漏总结
    Handler实现机制,同步屏障,IdleHandler
    launcher 配置
    微信小程序 上传图片七牛
    微信小程序 跳转传参数 传对象
  • 原文地址:https://www.cnblogs.com/zhouzhiyao/p/12551056.html
Copyright © 2011-2022 走看看