成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

[Leetcode] Longest Substring with At Most 2 Distin

imccl / 3543人閱讀

摘要:最新思路解法哈希表法復(fù)雜度時(shí)間空間思路我們遍歷字符串時(shí)用一個(gè)哈希表,但這個(gè)哈希表只記錄兩個(gè)東西,一個(gè)字母和它上次出現(xiàn)的時(shí)的下標(biāo),另一個(gè)字母和它上次出現(xiàn)時(shí)候的下標(biāo)。這個(gè)通過用哈希表記錄字母上次出現(xiàn)的下標(biāo),來維護(hù)一個(gè)窗口的方法也可以用于。

Longest Substring with At Most Two Distinct Characters 最新思路解法:https://yanjia.me/zh/2018/12/...
Given a string, find the length of the longest substring T that contains at most 2 distinct characters.

For example, Given s = “eceba”,

T is "ece" which its length is 3.

哈希表法 復(fù)雜度

時(shí)間 O(N) 空間 O(1)

思路

我們遍歷字符串時(shí)用一個(gè)哈希表,但這個(gè)哈希表只記錄兩個(gè)東西,一個(gè)字母和它上次出現(xiàn)的時(shí)的下標(biāo),另一個(gè)字母和它上次出現(xiàn)時(shí)候的下標(biāo)。這樣,如果新來的字母已經(jīng)存在與表中,或者表中現(xiàn)在少于兩個(gè)字母,就沒關(guān)系,我們只要更新下它新的下標(biāo)就行了。如果不存在于表中,則找出表中兩個(gè)字母中,靠前面的那個(gè),然后把這個(gè)較前的字母去掉,再加入這個(gè)新的字母。這樣,我們就能維護(hù)一個(gè)窗口,保證其中只有兩種字母。每次加入新字母時(shí),說明上一個(gè)子串已經(jīng)達(dá)到最長(zhǎng)了,這時(shí)候我們判斷下時(shí)候要更新全局最長(zhǎng)子串就行了。這個(gè)通過用哈希表記錄字母上次出現(xiàn)的下標(biāo),來維護(hù)一個(gè)窗口的方法也可以用于Longest Substring Without Repeating Characters。

注意

遍歷完之后還要一個(gè)額外判斷最長(zhǎng)子串的代碼來處理最后一個(gè)子串

加入新字母后,新子串的起始位置是被除去字母最后一次出現(xiàn)位置的后一個(gè)

代碼

Java

public class Solution {
    public int lengthOfLongestSubstringTwoDistinct(String s) {
        String longestSubstr = "";
        int maxLength = 0, start = 0;
        HashMap map = new HashMap();
        for(int i = 0; i < s.length(); i++){
            char c = s.charAt(i);
            // 如果表中已經(jīng)有兩個(gè)字母,且遇到了表中沒有的新字母時(shí),加入新字母
            if(map.size() >= 2 && !map.containsKey(c)){
                int leftMost = s.length();
                // 先計(jì)算出新字母之前的子串的長(zhǎng)度
                if(i - start > maxLength){
                    longestSubstr = s.substring(start, i);
                    maxLength = i - start;
                }
                // 找出哪個(gè)字母更靠前,將其去除
                for(Character key : map.keySet()){
                    if(map.get(key) maxLength){
            longestSubstr = s.substring(start, s.length());
            maxLength = s.length() - start;
        }
        return maxLength;
    }
}

Go

func lengthOfLongestSubstringTwoDistinct(s string) int {
    chars := map[byte]int{}
    start := 0
    maxLength := 0
    for index := 0; index < len(s); index++ {
        char := s[index]
        if _, ok := chars[char]; !ok && len(chars) >= 2 {
            minIndex := len(s)
            for _, value := range chars {
                if value < minIndex {
                    minIndex = value
                }
            }
            start = minIndex + 1
            delete(chars, s[minIndex])
        }
        length := index - start + 1
        if maxLength < length {
            maxLength = length
        }
        chars[char] = index
    }
    return maxLength
}
后續(xù) Follow Up

Q:如果可以有k個(gè)distinct字母,怎么做?
A:將上題中的2換成k就行了。當(dāng)HashMap的大小大于k時(shí),我們才將最早出現(xiàn)的字母移去。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/64588.html

相關(guān)文章

  • [LeetCode] 159. Longest Substring with At Most Two

    Problem Given a string s , find the length of the longest substring t that contains at most 2 distinct characters. Example 1: Input: ecebaOutput: 3Explanation: t is ece which its length is 3.Example ...

    geekidentity 評(píng)論0 收藏0
  • 159. Longest Substring with At Most Two Distinct C

    摘要:表示某個(gè)最后一次出現(xiàn)的地方可能只包含一種或者兩種只包含一種強(qiáng)制保持出現(xiàn)兩種保證,為了計(jì)算方便出現(xiàn)第三種的時(shí)候,直接計(jì)算出當(dāng)前長(zhǎng)度。 Given a string, find the length of the longest substring T that contains at most 2 distinct characters. For example, Given s = e...

    liujs 評(píng)論0 收藏0
  • [leetcode] Minimum Window Substring

    摘要:使用而不是因?yàn)槲覀冃枰氖亲钪担虚g值我們不在乎,所以一次收斂到最小。下面來三個(gè)需要查重并且記錄上次出現(xiàn)的位置,選擇以為例,走到用做檢查,發(fā)現(xiàn)出現(xiàn)過,把移到的下一個(gè)。是上個(gè)題目的簡(jiǎn)易版,或者特殊版。 這里聊一聊解一類問題,就是滿足某一條件的substring最值問題。最開始我們以Minimum Window Substring為例,并整理總結(jié)leetcode里所有類似題目的通解。 Gi...

    Pines_Cheng 評(píng)論0 收藏0
  • 159. Longest Substring With At Most Two Distinct C

    摘要:題目解法最重要的是把最后一次出現(xiàn)的這個(gè)的記在的里面。所以當(dāng)出現(xiàn)不止兩個(gè)的數(shù)的時(shí)候,把這個(gè)最低的刪掉,把最的加就可以啦 題目:Given a string, find the length of the longest substring T that contains at most 2 distinct characters. For example, Given s = eceba...

    spacewander 評(píng)論0 收藏0
  • [Leetcode] Substring with Concatenation of All Wor

    摘要:每次搜索中,我們通過哈希表維護(hù)一個(gè)窗口,比如中,我們先拿出。如果都不在數(shù)組中,那說明根本不能拼進(jìn)去,則哈希表全部清零,從下一個(gè)詞開始重新匹配。 Substring with Concatenation of All Words You are given a string, s, and a list of words, words, that are all of the same...

    adie 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<