算法刷題筆記【數(shù)組】01

算法刷題筆記【數(shù)組】01

數(shù)組理論

數(shù)組是存放在連續(xù)內(nèi)存空間上的相同類(lèi)型數(shù)據(jù)的集合蒸走。

數(shù)組可以方便的通過(guò)下標(biāo)索引的方式獲取到下標(biāo)下對(duì)應(yīng)的數(shù)據(jù)。

注意

數(shù)組下標(biāo)都是從0開(kāi)始的捻艳。

數(shù)組內(nèi)存空間的地址是連續(xù)的

因?yàn)閿?shù)組的在內(nèi)存空間的地址是連續(xù)的驾窟,所以我們?cè)趧h除或者增添元素的時(shí)候,就難免要移動(dòng)其他元素的地址认轨。

數(shù)組例題

704.二分查找

題目:給定一個(gè) n 個(gè)元素有序的(升序)整型數(shù)組 nums 和一個(gè)目標(biāo)值 target 绅络,寫(xiě)一個(gè)函數(shù)搜索 nums 中的 target嘁字,如果目標(biāo)值存在返回下標(biāo)恩急,否則返回 -1。

示例 1:

輸入: nums = [-1,0,3,5,9,12], target = 9

輸出: 4

解釋: 9 出現(xiàn)在 nums 中并且下標(biāo)為 4

示例 2:

輸入: nums = [-1,0,3,5,9,12], target = 2

輸出: -1

解釋: 2 不存在 nums 中因此返回 -1

提示:

你可以假設(shè) nums 中的所有元素是不重復(fù)的纪蜒。

n 將在 [1, 10000]之間灭袁。

nums 的每個(gè)元素都將在 [-9999, 9999]之間举娩。

分析過(guò)程

【文字太長(zhǎng)不看系列:↓直接跳到末尾查看打印出循環(huán)過(guò)程的代碼便于理解】

循環(huán)不變量

區(qū)間定義后,每次改變區(qū)間后芙代,區(qū)間性質(zhì)不能變:保持 左閉右閉[a, b] / 左閉右開(kāi)[a, b),處理規(guī)則要按照區(qū)間定義來(lái)寫(xiě),使得每次操作的范圍劃分滿足區(qū)間的定義躏敢。

1.左閉右閉 [a, b]

while(left ?? right)

分析:如何判斷問(wèn)號(hào)處該使用小于(<)號(hào)還是小于等于(<=)號(hào)件余?

例如:當(dāng)下標(biāo)區(qū)間為[x,x]時(shí)讥脐,此時(shí)區(qū)間長(zhǎng)度為1,區(qū)間內(nèi)只有一個(gè)元素蛾扇。while判斷條件若使用"<="攘烛,則?left=nums[x]魏滚,right=nums[x]镀首,此時(shí)條件?left<=right?成立,能使得進(jìn)入循環(huán)的區(qū)間滿足循環(huán)不變鼠次;若使用"<"更哄,left=nums[x]芋齿,right=nums[x],此時(shí)條件?left<right?不成立成翩,無(wú)法使進(jìn)入循環(huán)的區(qū)間滿足循環(huán)不變觅捆。

簡(jiǎn)單來(lái)看,閉區(qū)間麻敌,左邊界==右邊界是有意義的栅炒,因此判斷條件可以寫(xiě)成?left <= right

target < nums[mid] 時(shí)如何更新右邊界 right

分析:右邊界更新為 mid 還是 mid - 1术羔?

若目標(biāo)值小于二分后的中值赢赊,即?target < nums[mid],則?nums[mid]?一定不在要查找的范圍內(nèi)级历,不可能為要查找的目標(biāo)值释移,即?target!=nums[mid]。此時(shí)更新右邊界值寥殖,right?的正確更新方式為?right = mid - 1玩讳,而非?right = mid,否則就將不屬于查找范圍中的值?nums[mid]?包含了進(jìn)來(lái)嚼贡。若錯(cuò)誤采用了?right < mid?寫(xiě)法熏纯,緊接下來(lái)的循環(huán)可能不會(huì)立即導(dǎo)致錯(cuò)誤,但當(dāng)程序運(yùn)行到二分區(qū)間只剩一個(gè)元素時(shí)粤策,很可能時(shí)本該被查到的目標(biāo)值因?yàn)椴粷M足?left < right?條件而退出循環(huán)豆巨,導(dǎo)致最終找不到目標(biāo)值。

target > nums[mid] 時(shí)如何更新左邊界 left

分析:左邊界更新為 mid 還是 mid - 1掐场?

由右邊界更新方式同理可知往扔,nums[mid]?不在區(qū)間中,左邊界更新只需?left = mid + 1?熊户。

2.左閉右開(kāi)[a, b)

while(left ?? right)

分析:如何判斷問(wèn)號(hào)處該使用小于(<)號(hào)還是小于等于(<=)號(hào)萍膛?

例如:當(dāng)下標(biāo)區(qū)間為[x,x)時(shí),此時(shí)區(qū)間長(zhǎng)度為1嚷堡,區(qū)間內(nèi)只有一個(gè)元素蝗罗。while判斷條件若使用"<=",則表示可以有?left=nums[x]蝌戒,right=nums[x]串塑,此時(shí)條件?left<=right?,不能使得進(jìn)入循環(huán)的區(qū)間滿足循環(huán)不變北苟;若使用"<"桩匪,left=nums[x]right=nums[x+1]友鼻,此時(shí)條件?left<right?成立傻昙,使進(jìn)入循環(huán)的區(qū)間滿足循環(huán)不變闺骚。

簡(jiǎn)單來(lái)看,閉區(qū)間妆档,**左邊界==右邊界 **是有意義的僻爽,因此判斷條件可以寫(xiě)成?left <= right

target < nums[mid] 時(shí)如何更新右邊界 right

分析:右邊界更新為 mid 還是 mid - 1贾惦?

若目標(biāo)值小于二分后的中值胸梆,即?target < nums[mid],則?nums[mid]?一定不在要查找的范圍內(nèi)须板,不可能為要查找的目標(biāo)值乳绕,即?target!=nums[mid]。此時(shí)更新右邊界值逼纸,right?可更新為?right = mid?洋措,表示取不到?mid?,而非?right = mid - 1杰刽,否則就將應(yīng)該屬于查找范圍中的值?nums[mid - 1]?剔除了菠发。

target > nums[mid] 時(shí)如何更新左邊界 left

分析:左邊界更新為 mid 還是 mid - 1?

由1中閉區(qū)間更新方式贺嫂,同理可知滓鸠,nums[mid]?不在區(qū)間中,左邊界更新仍為?left = mid + 1?第喳。

小結(jié)

將數(shù)組區(qū)間和數(shù)學(xué)數(shù)列中的區(qū)間聯(lián)系起來(lái)也很好理解糜俗。

左閉右閉方式,將一個(gè)完整區(qū)間分為3部分?(<t, =t, >t)曲饱,最終左右邊界會(huì)相等悠抹,指向最后一次查找的位置;

左閉右開(kāi)方式扩淀,將一個(gè)完整區(qū)間分為2部分?(<t, >=t)楔敌,該方式左右邊界不會(huì)有相等的情況,只會(huì)相鄰驻谆。

題解

算法刷題筆記【數(shù)組】01@蘭鐵二幼張同學(xué)-博客園

算法刷題筆記【數(shù)組】01@蘭鐵二幼張同學(xué)-CSDN

算法刷題筆記【數(shù)組】01@蘭鐵二幼張同學(xué)-稀土掘金

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末卵凑,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子胜臊,更是在濱河造成了極大的恐慌勺卢,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件象对,死亡現(xiàn)場(chǎng)離奇詭異黑忱,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)杨何,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人沥邻,你說(shuō)我怎么就攤上這事危虱。” “怎么了唐全?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵埃跷,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我邮利,道長(zhǎng)弥雹,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任延届,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘秧了。我一直安慰自己有咨,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布械念。 她就那樣靜靜地躺著头朱,像睡著了一般。 火紅的嫁衣襯著肌膚如雪龄减。 梳的紋絲不亂的頭發(fā)上项钮,一...
    開(kāi)封第一講書(shū)人閱讀 51,692評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音希停,去河邊找鬼烁巫。 笑死,一個(gè)胖子當(dāng)著我的面吹牛宠能,可吹牛的內(nèi)容都是我干的程拭。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼棍潘,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼恃鞋!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起亦歉,我...
    開(kāi)封第一講書(shū)人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤恤浪,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后肴楷,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體水由,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年赛蔫,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了砂客。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片泥张。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖鞠值,靈堂內(nèi)的尸體忽然破棺而出媚创,到底是詐尸還是另有隱情,我是刑警寧澤彤恶,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布钞钙,位于F島的核電站,受9級(jí)特大地震影響声离,放射性物質(zhì)發(fā)生泄漏芒炼。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一术徊、第九天 我趴在偏房一處隱蔽的房頂上張望本刽。 院中可真熱鬧,春花似錦赠涮、人聲如沸盅安。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)别瞭。三九已至,卻和暖如春株憾,著一層夾襖步出監(jiān)牢的瞬間蝙寨,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工嗤瞎, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留墙歪,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓贝奇,卻偏偏與公主長(zhǎng)得像虹菲,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子掉瞳,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

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