前端算法題 | 這道題效率最高的算法念恍,你可能不知道六剥?

11111.jpg

尋找最長的不含有重復(fù)字符的子串

可能看標(biāo)題不會明白這個(gè)題到底什么意思,來看看下面的例子:

  • abcabcbb ? abc ? 3

  • bbbb ? b ? 1

  • pwwkew ? wke ? 3

看了栗子是不是明白了呢峰伙?

其實(shí)需求很簡單疗疟,實(shí)現(xiàn)的方法也很多,不過在這里我要來寫一種效率最高的算法瞳氓,只需要一次循環(huán)就可解決:

function findNoRepeatMaxLenStr (str) {

  let lastPositions = {}

  let start = 0

  let maxLen = 0

  for (let i=0; i<str.length; i++) {

        const s = str[i]

        if (lastPositions[s] !== 'undefined' && lastPositions[s] >= start) {

              start = lastPositions[s] + 1

        }

        if (i - start + 1 > maxLen) {

              maxLen = i - start + 1

        }

    lastPositions[s] = i

  }

  return maxLen

}

// test

console.log(findNoRepeatMaxLenStr('abcabcbb'))  // 3

那么看完代碼策彤,請自己先胡思亂想一下,能看得懂不?

行了店诗,看到這我就知道你沒看懂裹刮,那么來解釋一下吧。

思路是這樣的必搞,假如下面的圖形是一個(gè)字符串必指,每個(gè)格子代表一個(gè)字符:

image

此時(shí)咱們開始使用 for 循環(huán)掃描整個(gè)字符串,當(dāng)掃描到 x(x 代表任意位置的任意的字符串)的時(shí)候恕洲,那么咱們應(yīng)該怎么做呢塔橡?

首先要記錄一個(gè) start 起始位置,當(dāng)然一開始就是 0 了霜第,那么 start 在循環(huán)中不僅僅只是表示字符串從 0 開始葛家,還表示當(dāng)前不含有最長重復(fù)子串的開始,那么咱們要做的事情就一件:保證從 start 到 x 之間沒有重復(fù)的字符串泌类,再說的通俗點(diǎn)就是看檢查 start 到 x 之間有沒有重復(fù)的 x 癞谒。

那么怎么做到檢查這個(gè)動作呢?

這個(gè)時(shí)候 lastPositions 就派上用場了。當(dāng)循環(huán)到 x 的時(shí)候刃榨,記錄一下這個(gè) x 最后一次出現(xiàn)的位置在哪里弹砚。

那么記錄完畢之后,當(dāng)進(jìn)行檢查 start 到 x 之間 是否有重復(fù)的 x 的時(shí)候枢希,咱們就去問 lastPositions[x]桌吃,此時(shí)會有2種情況:

  • 第一種情況是 x 從來沒有出現(xiàn)過或者出現(xiàn)在了 start 之前;

  • 第二種情況是 x 出現(xiàn)在 start 到 x 中間苞轿。

那么對于第一種情況茅诱,咱們不用去管。而第二種情況自然是不滿足條件的情況了搬卒,此時(shí)瑟俭,咱們就要更新 lastPositions[x],將這個(gè) x 的位置更新為 lastPositions[x] + 1契邀。

總結(jié)下來就是:

  • lastPositions[x] 不存在或 < start 滿足條件摆寄,無需操作

  • lastPositions[x] 存在并且 >= start 不滿足條件,更新 lastPositions[x]++

那么在結(jié)合上面的代碼蹂安,邏輯就清晰了椭迎,唯一有些繞圈圈的地方就是第二個(gè) if 中的 +1 操作,原因就是字符串的索引是從 0 開始的田盈,那么假如第一個(gè)為 x 滿足條件畜号,實(shí)際索引是0,那么長度應(yīng)該是 0 + 1 = 1允瞧。

最后简软,這道算法題的出處來自:

覺得本文對你有幫助痹升?請分享給更多人

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末建炫,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子疼蛾,更是在濱河造成了極大的恐慌肛跌,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件察郁,死亡現(xiàn)場離奇詭異衍慎,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)皮钠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門稳捆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人麦轰,你說我怎么就攤上這事乔夯。” “怎么了款侵?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵末荐,是天一觀的道長。 經(jīng)常有香客問我新锈,道長鞠评,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任壕鹉,我火速辦了婚禮,結(jié)果婚禮上聋涨,老公的妹妹穿的比我還像新娘晾浴。我一直安慰自己,他們只是感情好牍白,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布脊凰。 她就那樣靜靜地躺著,像睡著了一般茂腥。 火紅的嫁衣襯著肌膚如雪狸涌。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天最岗,我揣著相機(jī)與錄音帕胆,去河邊找鬼。 笑死般渡,一個(gè)胖子當(dāng)著我的面吹牛懒豹,可吹牛的內(nèi)容都是我干的芙盘。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼脸秽,長吁一口氣:“原來是場噩夢啊……” “哼儒老!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起记餐,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤驮樊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后片酝,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體囚衔,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年钠怯,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了佳魔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,605評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡晦炊,死狀恐怖鞠鲜,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情断国,我是刑警寧澤贤姆,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站稳衬,受9級特大地震影響霞捡,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜薄疚,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一碧信、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧街夭,春花似錦砰碴、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至埃碱,卻和暖如春猖辫,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背砚殿。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工啃憎, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人似炎。 一個(gè)月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓荧飞,卻偏偏與公主長得像凡人,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子叹阔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評論 2 348

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

  • 第2章 基本語法 2.1 概述 基本句法和變量 語句 JavaScript程序的執(zhí)行單位為行(line)挠轴,也就是一...
    悟名先生閱讀 4,131評論 0 13
  • 前言 最先接觸編程的知識是在大學(xué)里面岸晦,大學(xué)里面學(xué)了一些基礎(chǔ)的知識,c語言睛藻,java語言启上,單片機(jī)的匯編語言等;大學(xué)畢...
    oceanfive閱讀 3,048評論 0 7
  • 微笑已經(jīng)變成了安慰自己安慰他人的最無能為力的表現(xiàn)店印,好比關(guān)心時(shí)卻只能說出一句多喝水一樣冈在。 我天生愛笑,小...
    小橘子小閱讀 94評論 0 0
  • 薔薇花開花又謝按摘, 一場相遇一場劫包券。 共賦清愁詩幾闋, 隔橋相對飲青階炫贤。 ——作者:柳塵微
    柳塵微閱讀 188評論 3 3