劍指offer-最長(zhǎng)不含重復(fù)字符的子字符串-JavaScript

題目描述:請(qǐng)從字符串中找出一個(gè)最長(zhǎng)的不包含重復(fù)字符的子字符串,計(jì)算該最長(zhǎng)子字符串的長(zhǎng)度。

題目分析

留意最長(zhǎng)子串和子序列不是一個(gè)概念。例如對(duì)“pwwkew”來說,最長(zhǎng)子串是“wke”,“pwke”是其中一個(gè)子序列。

在不考慮時(shí)間的情況下,直接暴力法對(duì)所有的子串進(jìn)行檢查。復(fù)雜度是O(N^3),會(huì)超時(shí)錯(cuò)誤。

解法 1: 滑動(dòng)窗口

準(zhǔn)備 2 個(gè)指針 i、j,i 指向窗口左邊,j 指向右邊。指針每次可以向前“滑動(dòng)”一個(gè)位置,它們之間的區(qū)域就是“窗口”。

整體流程如下:

  1. 準(zhǔn)備哈希表 map。key 是 char,value 是 boolean,代表字符 char 是否出現(xiàn)在滑動(dòng)窗口內(nèi)
  2. i 和 j 初始化為 0,結(jié)果 ans 初始化為 0
  3. 檢查s[j]是否出現(xiàn)過:
    • 沒有出現(xiàn)過,擴(kuò)大窗口:記錄s[j],指針 j 向右滑動(dòng)一格,更新 ans
    • 出現(xiàn)過,縮小窗口:指針 i 向右移動(dòng)一格,map[s[i]]更新為 false
  4. 如果 i 和 j 沒有越界,回到 step3,否則返回 ans

代碼實(shí)現(xiàn)如下:

// ac地址:https://leetcode-cn.com/problems/zui-chang-bu-han-zhong-fu-zi-fu-de-zi-zi-fu-chuan-lcof/
// 原文地址:https://xxoo521.com/2020-03-11-length-of-substring/

/**
 * @param {string} s
 * @return {number}
 */
var lengthOfLongestSubstring = function(s) {
    const length = s.length;
    const map = {}; // char => boolean 代表著char是否在目前的窗口內(nèi)
    let i = 0,
        j = 0;
    let ans = 0;
    while (i < length && j < length) {
        if (!map[s[j]]) {
            ans = Math.max(j - i + 1, ans);
            map[s[j]] = true;
            ++j;
        } else {
            // 如果char重復(fù),那么縮小滑動(dòng)窗口,并更新對(duì)應(yīng)的map
            map[s[i]] = false;
            ++i;
        }
    }

    return ans;
};

由于整個(gè)過程就是“推著”滑動(dòng)窗口從左到右,時(shí)間復(fù)雜度是O(N),空間復(fù)雜度是O(N)

解法 2: 優(yōu)化后的滑動(dòng)窗口

在解法 1 的流程中的第 3 步,如果s[j]出現(xiàn)在滑動(dòng)窗口內(nèi),采用的做法是左邊逐步縮小滑動(dòng)窗口。事實(shí)上,不需要逐步縮小。假設(shè)滑動(dòng)窗口內(nèi)和s[j]相同字符下標(biāo)是 j',那么直接跳過[i, j'] 范圍即可。

為了做到“跳動(dòng)優(yōu)化”,需要改造一下對(duì)哈希表 map 的用法:key 還是 char;value 變?yōu)?int,記錄 char 對(duì)應(yīng)的下標(biāo)。

整體代碼實(shí)現(xiàn)如下:

// ac地址:https://leetcode-cn.com/problems/zui-chang-bu-han-zhong-fu-zi-fu-de-zi-zi-fu-chuan-lcof/
// 原文地址:https://xxoo521.com/2020-03-11-length-of-substring/

/**
 * @param {string} s
 * @return {number}
 */
var lengthOfLongestSubstring = function(s) {
    const length = s.length;
    const map = new Map();
    let i = 0,
        j = 0;
    let ans = 0;
    while (i < length && j < length) {
        // 容易理解:檢查s[j]是否出現(xiàn)過,并且s[j]重復(fù)的字符是否在當(dāng)前的滑動(dòng)窗口中
        if (map.has(s[j]) && map.get(s[j]) >= i) {
            i = map.get(s[j]) + 1;
        }
        ans = Math.max(j - i + 1, ans);
        map.set(s[j], j);
        ++j;
    }
    return ans;
};

更多資料

整理不易,若對(duì)您有幫助,請(qǐng)給個(gè)「關(guān)注+點(diǎn)贊」,您的支持是我更新的動(dòng)力 ??

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,156評(píng)論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,401評(píng)論 3 415
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,069評(píng)論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,873評(píng)論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,635評(píng)論 6 408
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,128評(píng)論 1 323
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,203評(píng)論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,365評(píng)論 0 288
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,881評(píng)論 1 334
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,733評(píng)論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,935評(píng)論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,475評(píng)論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,172評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,582評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,821評(píng)論 1 282
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,595評(píng)論 3 390
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,908評(píng)論 2 372

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