摘要:最新思路解法哈希表法復(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.哈希表法 復(fù)雜度For example, Given s = “eceba”,
T is "ece" which its length is 3.
時(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; HashMapmap = 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
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 ...
摘要:表示某個(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...
摘要:使用而不是因?yàn)槲覀冃枰氖亲钪担虚g值我們不在乎,所以一次收斂到最小。下面來三個(gè)需要查重并且記錄上次出現(xiàn)的位置,選擇以為例,走到用做檢查,發(fā)現(xiàn)出現(xiàn)過,把移到的下一個(gè)。是上個(gè)題目的簡(jiǎn)易版,或者特殊版。 這里聊一聊解一類問題,就是滿足某一條件的substring最值問題。最開始我們以Minimum Window Substring為例,并整理總結(jié)leetcode里所有類似題目的通解。 Gi...
摘要:題目解法最重要的是把最后一次出現(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...
摘要:每次搜索中,我們通過哈希表維護(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...
閱讀 3326·2021-09-08 09:45
閱讀 1261·2019-08-30 15:53
閱讀 1538·2019-08-30 14:12
閱讀 989·2019-08-29 17:01
閱讀 2579·2019-08-29 15:35
閱讀 401·2019-08-29 13:09
閱讀 1982·2019-08-29 12:32
閱讀 3093·2019-08-26 18:37