帶你了解數(shù)據(jù)結(jié)構(gòu)與算法眯牧。附leetcode練習

算法+ 數(shù)據(jù)結(jié)構(gòu) = 程序


導讀

1.1 為什么要學習數(shù)據(jù)結(jié)構(gòu)與算法

    很多人認為學習數(shù)據(jù)結(jié)構(gòu)與算法只是為了應付面試话浇,在日常的開發(fā)中基本上沒有使用的機會挽鞠,也有一些同學去刷題牵署,但發(fā)現(xiàn)有時候這些題目一看就會一問就費的局面漏隐。甚至有一些的同學看到數(shù)據(jù)結(jié)構(gòu)和算法這一詞時內(nèi)心直接就是抵觸的。

這里很大的一部分原因是因為你沒有真正的去了解數(shù)據(jù)結(jié)構(gòu)奴迅,你有想過為什么大廠都要求數(shù)據(jù)結(jié)構(gòu)與算法嗎青责?為什么技術(shù)過關(guān)了但是總會掛在算法這一關(guān)?

學習數(shù)據(jù)結(jié)構(gòu)與算法不僅僅是學習其中的數(shù)組取具,鏈表脖隶,隊列,堆棧暇检,樹产阱,圖等經(jīng)典的結(jié)構(gòu),也不僅僅是學習應付面試的算法块仆。

其實數(shù)據(jù)結(jié)構(gòu)是考驗你的基本功是否扎實的重要環(huán)節(jié)之一构蹬,最重要的是你要學習一種思想:如何把現(xiàn)實問題轉(zhuǎn)化為計算機語言的表示。

算法+ 數(shù)據(jù)結(jié)構(gòu) = 程序

本篇文章將介紹數(shù)據(jù)結(jié)構(gòu)中的基礎概念悔据,了解基礎概念之后會配套的做一些相關(guān)的練習題加深對其的理解庄敛。希望能對你得到一些幫助。

這個專題也會不斷的向內(nèi)添加內(nèi)容科汗,如有圖片或者描述錯誤的地方或者講解不清楚的地方還請各位同學及時指出藻烤,我加以改正。

目前已完成數(shù)據(jù)結(jié)構(gòu)的基本概念 相關(guān)算法題會在編輯算法章節(jié)時陸續(xù)補充進來肛捍。感謝關(guān)注隐绵。

1.2 什么是數(shù)據(jù)結(jié)構(gòu)與算法

    [數(shù)據(jù)](https://baike.baidu.com/item/數(shù)據(jù)/5947370)結(jié)構(gòu)是[計算機](https://baike.baidu.com/item/計算機/140338)存儲、組織[數(shù)據(jù)](https://baike.baidu.com/item/數(shù)據(jù))的方式拙毫。數(shù)據(jù)結(jié)構(gòu)是指相互之間存在一種或多種特定關(guān)系的[數(shù)據(jù)元素](https://baike.baidu.com/item/數(shù)據(jù)元素/715313)的集合依许。通常情況下,精心選擇的數(shù)據(jù)結(jié)構(gòu)可以帶來更高的運行或者存儲[效率](https://baike.baidu.com/item/效率/868847)缀蹄。數(shù)據(jù)結(jié)構(gòu)往往同高效的檢索[算法](https://baike.baidu.com/item/算法/209025)和[索引](https://baike.baidu.com/item/索引/5716853)技術(shù)有關(guān)峭跳。

數(shù)據(jù)結(jié)構(gòu)包括:

  1. 線性結(jié)構(gòu):線性表(數(shù)組膘婶、鏈表、隊列蛀醉、棧悬襟、哈希表)

  2. 樹型結(jié)構(gòu):二叉樹、AVL樹拯刁、紅黑樹脊岳、B樹、堆垛玻、Trie割捅、哈夫曼樹、并查集

  3. 圖形結(jié)構(gòu):鄰接矩陣帚桩、鄰接表

     算法(Algorithm)是指解題方案的準確而完整的描述亿驾,是一系列解決問題的清晰指令,算法代表著用系統(tǒng)的方法描述解決問題的策略機制 
    

算法包括:遞推法账嚎、遞歸法莫瞬、窮舉法、貪心算法郭蕉、分治法疼邀、動態(tài)規(guī)劃法、迭代法召锈、分支界限法檩小、回溯法

一. 算法基本概念

    算法(Algorithm)是指解題方案的準確而完整的描述,是一系列解決問題的清晰指令烟勋,算法代表著用系統(tǒng)的方法描述解決問題的策略機制

一個算法的優(yōu)劣可以用空間復雜度與時間復雜度來衡量。

特征:

  1. 有窮性(Finiteness):算法的有窮性是指算法必須能在執(zhí)行有限個步驟之后終止筐付。
  2. 確切性(Definiteness): 算法的每一步驟必須有確切的定義卵惦。
  3. 輸入項(Input)::一個算法有0個或多個輸入,以刻畫運算對象的初始情況瓦戚,所謂0個輸入是指算法本身定出了初始條件沮尿。
  4. 輸出項(Output):一個算法有一個或多個輸出,以反映對輸入數(shù)據(jù)加工后的結(jié)果较解。沒有輸出的算法是毫無意義的畜疾。
  5. 可行性(Effectiveness):算法中執(zhí)行的任何計算步驟都是可以被分解為基本的可執(zhí)行的操作步驟,即每個計算步驟都可以在有限時間內(nèi)完成(也稱之為有效性)印衔。

1.1 時間復雜度

    算法的時間復雜度是指執(zhí)行算法所需要的計算工作量啡捶。也就是說程序需要執(zhí)行的次數(shù)

大O表示法

一般用大O表示法來描述負責度,它表示的是數(shù)據(jù)規(guī)模為n對應的復雜度

  • 忽略常數(shù)奸焙、系數(shù)瞎暑、低階

    執(zhí)行次數(shù) 復雜度 非正式術(shù)語
    12 O(1) 常數(shù)階
    2n+3 O(n) 線性階
    4n^2+2n+6 O(n^2) 平方階
    4log2n+25 O(logn) 對數(shù)階
    3n+2nlog3n+15 O(nlogn) nlogn階
    4n3+3n2+n+12 O(n^3) 立方階
    2^n O(2^n) 指數(shù)階
img

O(1) < O(logn) < O(n) < O(nlogn) < O(n^2) < O(n^3) < O(2^n) < O(n!) < O(n^n)

1.2 空間復雜度

    空間復雜度(Space Complexity)是對一個算法在運行過程中臨時占用存儲空間大小的量度彤敛,記做S(n)=O(f(n))。比如直接插入排序的時間復雜度是O(n^2),空間復雜度是O(1) 了赌。而一般的遞歸算法就要有O(n)的空間復雜度了墨榄,因為每次遞歸都要存儲返回信息。一個算法的優(yōu)劣主要從算法的執(zhí)行時間和所需要占用的存儲空間兩個方面衡量)勿她。

二. 數(shù)據(jù)結(jié)構(gòu) - 線性結(jié)構(gòu)()

圖文介紹:
帶你了解數(shù)據(jù)結(jié)構(gòu)與算法袄秩。附leetcode練習
算法 - 十大經(jīng)典排序算法(動圖演示)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市逢并,隨后出現(xiàn)的幾起案子之剧,更是在濱河造成了極大的恐慌,老刑警劉巖筒狠,帶你破解...
    沈念sama閱讀 218,682評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件猪狈,死亡現(xiàn)場離奇詭異,居然都是意外死亡辩恼,警方通過查閱死者的電腦和手機雇庙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來灶伊,“玉大人疆前,你說我怎么就攤上這事∑溉” “怎么了竹椒?”我有些...
    開封第一講書人閱讀 165,083評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長米辐。 經(jīng)常有香客問我胸完,道長,這世上最難降的妖魔是什么翘贮? 我笑而不...
    開封第一講書人閱讀 58,763評論 1 295
  • 正文 為了忘掉前任赊窥,我火速辦了婚禮,結(jié)果婚禮上狸页,老公的妹妹穿的比我還像新娘锨能。我一直安慰自己,他們只是感情好芍耘,可當我...
    茶點故事閱讀 67,785評論 6 392
  • 文/花漫 我一把揭開白布址遇。 她就那樣靜靜地躺著,像睡著了一般斋竞。 火紅的嫁衣襯著肌膚如雪倔约。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,624評論 1 305
  • 那天窃页,我揣著相機與錄音跺株,去河邊找鬼复濒。 笑死,一個胖子當著我的面吹牛乒省,可吹牛的內(nèi)容都是我干的巧颈。 我是一名探鬼主播,決...
    沈念sama閱讀 40,358評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼袖扛,長吁一口氣:“原來是場噩夢啊……” “哼砸泛!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蛆封,我...
    開封第一講書人閱讀 39,261評論 0 276
  • 序言:老撾萬榮一對情侶失蹤唇礁,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后惨篱,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體盏筐,經(jīng)...
    沈念sama閱讀 45,722評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年砸讳,在試婚紗的時候發(fā)現(xiàn)自己被綠了琢融。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,030評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡簿寂,死狀恐怖漾抬,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情常遂,我是刑警寧澤纳令,帶...
    沈念sama閱讀 35,737評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站克胳,受9級特大地震影響平绩,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜漠另,卻給世界環(huán)境...
    茶點故事閱讀 41,360評論 3 330
  • 文/蒙蒙 一红且、第九天 我趴在偏房一處隱蔽的房頂上張望喇勋。 院中可真熱鬧尸昧,春花似錦建芙、人聲如沸来累。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽嘹锁。三九已至葫录,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間领猾,已是汗流浹背米同。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評論 1 270
  • 我被黑心中介騙來泰國打工骇扇, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人面粮。 一個月前我還...
    沈念sama閱讀 48,237評論 3 371
  • 正文 我出身青樓少孝,卻偏偏與公主長得像,于是被迫代替她去往敵國和親熬苍。 傳聞我的和親對象是個殘疾皇子稍走,可洞房花燭夜當晚...
    茶點故事閱讀 44,976評論 2 355

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