Day41 最小覆蓋子串

給你一個字符串 s 饵筑、一個字符串 t 个粱。返回 s 中涵蓋 t 所有字符的最小子串。如果 s 中不存在涵蓋 t 所有字符的子串翻翩,則返回空字符串 ""

https://leetcode-cn.com/problems/minimum-window-substring/

注意:如果 s 中存在這樣的子串,我們保證它是唯一的答案稻薇。

示例1:

輸入:s = "ADOBECODEBANC", t = "ABC"
輸出:"BANC"

示例2:

輸入:s = "a", t = "a"
輸出:"a"

提示:

1 <= s.length, t.length <= 105
s 和 t 由英文字母組成

Java解法

思路:

  • 初步想法:滑動數(shù)組來處理嫂冻,在找到匹配字符時數(shù)據(jù)開始匹配,匹配到全部時塞椎,開始移動數(shù)組桨仿,在移動過程中記錄最短字符匹配串,但考慮到重復字符匹配沒有很好的記錄方式暫時卡住
  • 參考官方解案狠,使用hashmap存儲char及個數(shù)服傍,不用記錄位置,只做當前窗口是否符合要求的判斷
package sj.shimmer.algorithm.m2;

import java.util.HashMap;
import java.util.Map;

/**
 * Created by SJ on 2021/3/6.
 */


class D41 {
    public static void main(String[] args) {
//        System.out.println(minWindow("ADOBECODEBANC", "ABC"));
        System.out.println(minWindow("a", "a"));
    }

    static Map<Character, Integer> tCharNum = new HashMap<>();
    static Map<Character, Integer> mCharNum = new HashMap<>();

    public static String minWindow(String s, String t) {

        String matchS = "";

        if (s == null || s.equals("") || t == null || t.equals("")) {
            return matchS;
        }
        int tLength = t.length();
        int sLength = s.length();
        for (int i = 0; i < tLength; i++) {
            char key = t.charAt(i);
            tCharNum.put(key, tCharNum.getOrDefault(key, 0) + 1);
        }
        int resultLeft = -1;
        int resultRight = -1;
        int resultLength = Integer.MAX_VALUE;
        int left = 0;
        int right = -1;
        while (right < sLength) {
            right++;
            if (right < sLength && tCharNum.containsKey(s.charAt(right))) {
                mCharNum.put(s.charAt(right), mCharNum.getOrDefault(s.charAt(right), 0) + 1);
            }
            while (left <= right && checkIn()) {
                if (right - left + 1 < resultLength) {//記錄最短長度
                    resultLength = right - left + 1;
                    resultLeft = left;
                    resultRight = left + resultLength;//拼接時需要增加一位
                }
                if (tCharNum.containsKey(s.charAt(left))) {
                    mCharNum.put(s.charAt(left), mCharNum.getOrDefault(s.charAt(left), 0) - 1);
                }
                left++;
            }
        }
        matchS = resultLeft == -1 ? "" : s.substring(resultLeft, resultRight);
        return matchS;
    }

    private static boolean checkIn() {
        for (Map.Entry<Character, Integer> entry : tCharNum.entrySet()) {
            if (entry.getValue() > mCharNum.getOrDefault(entry.getKey(), 0)) {
                return false;
            }
        }
        return true;
    }
}
image

官方解

https://leetcode-cn.com/problems/minimum-window-substring/solution/zui-xiao-fu-gai-zi-chuan-by-leetcode-solution/

  1. 滑動窗口

    我的參考解法

    • 時間復雜度:O(C?∣s∣+∣t∣)

    • 空間復雜度: O(C) 骂铁,設(shè)字符集大小為 C

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末吹零,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子拉庵,更是在濱河造成了極大的恐慌灿椅,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件钞支,死亡現(xiàn)場離奇詭異茫蛹,居然都是意外死亡,警方通過查閱死者的電腦和手機烁挟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門婴洼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人撼嗓,你說我怎么就攤上這事柬采。” “怎么了且警?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵警没,是天一觀的道長。 經(jīng)常有香客問我振湾,道長杀迹,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮树酪,結(jié)果婚禮上浅碾,老公的妹妹穿的比我還像新娘。我一直安慰自己续语,他們只是感情好垂谢,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著疮茄,像睡著了一般滥朱。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上力试,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天徙邻,我揣著相機與錄音,去河邊找鬼畸裳。 笑死缰犁,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的怖糊。 我是一名探鬼主播帅容,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼伍伤!你這毒婦竟也來了并徘?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤扰魂,失蹤者是張志新(化名)和其女友劉穎饮亏,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體阅爽,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡路幸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了付翁。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片简肴。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖百侧,靈堂內(nèi)的尸體忽然破棺而出砰识,到底是詐尸還是另有隱情,我是刑警寧澤佣渴,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布辫狼,位于F島的核電站,受9級特大地震影響辛润,放射性物質(zhì)發(fā)生泄漏膨处。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望真椿。 院中可真熱鬧鹃答,春花似錦、人聲如沸突硝。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽解恰。三九已至锋八,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間护盈,已是汗流浹背挟纱。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留黄琼,地道東北人。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓整慎,卻偏偏與公主長得像脏款,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子裤园,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 題目描述:給你一個字符串 S撤师、一個字符串 T,請在字符串 S 里面找出:包含 T 所有字母的最小子串拧揽。 示例: 輸...
    windUtterance閱讀 215評論 0 0
  • 給你一個字符串 s 剃盾、一個字符串 t 。返回 s 中涵蓋 t 所有字符的最小子串淤袜。如果 s 中不存在涵蓋 t 所有...
    濱巖閱讀 161評論 0 0
  • 問題描述?給你一個字符串 S痒谴、一個字符串 T,請在字符串 S 里面找出:包含 T 所有字符的最小子串铡羡。 示例: 輸...
    zsdy閱讀 123評論 0 1
  • func minWindow(s string, t string) string {// 保存滑動窗口字符集wi...
    楊杰_18b7閱讀 157評論 0 0
  • 夜鶯2517閱讀 127,719評論 1 9