這10個(gè)程序員必知的基礎(chǔ)算法,你都了解嗎?我們一起來學(xué)習(xí)下資料下載
2021-04-22 |
pdf |
133.82KB |
次下載 |
2積分
資料介紹
1、快速排序算法
快速排序是由東尼?霍爾所發(fā)展的一種排序算法。在平均狀況下,排序n個(gè)項(xiàng)目要Ο(nlogn)次比較。在最壞狀況下則需要Ο(n2)次比較,但這種狀況并不常見。事實(shí)上,快速排序通常明顯比其他Ο(nlogn)算法更快,因?yàn)樗膬?nèi)部循環(huán)(innerloop)可以在大部分的架構(gòu)上很有效率地被實(shí)現(xiàn)出來。
快速排序使用分治法(Divideandconquer)策略來把一個(gè)串行(list)分為兩個(gè)子串行(sub-lists)。
算法步驟:
(1)從數(shù)列中挑出一個(gè)元素,稱為“基準(zhǔn)”(pivot),
(2)重新排序數(shù)列,所有元素比基準(zhǔn)值小的擺放在基準(zhǔn)前面,所有元素比基準(zhǔn)值大的擺在基準(zhǔn)的后面(相同的數(shù)可以到任一邊)。在這個(gè)分區(qū)退出之后,該基準(zhǔn)就處于數(shù)列的中間位置。這個(gè)稱為分區(qū)(partition)操作。
(3)遞歸地(recursive)把小于基準(zhǔn)值元素的子數(shù)列和大于基準(zhǔn)值元素的子數(shù)列排序。
遞歸的最底部情形,是數(shù)列的大小是零或一,也就是永遠(yuǎn)都已經(jīng)被排序好了。雖然一直遞歸下去,但是這個(gè)算法總會(huì)退出,因?yàn)樵诿看蔚牡?iteration)中,它至少會(huì)把一個(gè)元素?cái)[到它最后的位置去。
2、堆排序算法
堆排序(Heapsort)是指利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計(jì)的一種排序算法。堆積是一個(gè)近似完全二叉樹的結(jié)構(gòu),并同時(shí)滿足堆積的性質(zhì):即子結(jié)點(diǎn)的鍵值或索引總是小于(或者大于)它的父節(jié)點(diǎn)。
堆排序的平均時(shí)間復(fù)雜度為Ο(nlogn) 。
算法步驟:
(1)創(chuàng)建一個(gè)堆H[0..n-1]
(2)把堆首(最大值)和堆尾互換
(3)把堆的尺寸縮小1,并調(diào)用shift_down(0),目的是把新的數(shù)組頂端數(shù)據(jù)調(diào)整到相應(yīng)位置
(4)重復(fù)步驟2,直到堆的尺寸為1
3、歸并排序
歸并排序(Mergesort,臺灣譯作:合并排序)是建立在歸并操作上的一種有效的排序算法。該算法是采用分治法(DivideandConquer)的一個(gè)非常典型的應(yīng)用。
算法步驟:
(1)申請空間,使其大小為兩個(gè)已經(jīng)排序序列之和,該空間用來存放合并后的序列
(2)設(shè)定兩個(gè)指針,最初位置分別為兩個(gè)已經(jīng)排序序列的起始位置
(3)比較兩個(gè)指針?biāo)赶虻脑兀x擇相對小的元素放入到合并空間,并移動(dòng)指針到下一位置
(4)重復(fù)步驟3直到某一指針達(dá)到序列尾
(5)將另一序列剩下的所有元素直接復(fù)制到合并序列尾
4、二分查找算法
二分查找算法是一種在有序數(shù)組中查找某一特定元素的搜索算法。搜素過程從數(shù)組的中間元素開始,如果中間元素正好是要查找的元素,則搜素過程結(jié)束;如果某一特定元素大于或者小于中間元素,則在數(shù)組大于或小于中間元素的那一半中查找,而且跟開始一樣從中間元素開始比較。如果在某一步驟數(shù)組為空,則代表找不到。這種搜索算法每一次比較都使搜索范圍縮小一半。折半搜索每次把搜索區(qū)域減少一半,時(shí)間復(fù)雜度為Ο(logn) 。
5、BFPRT(線性查找算法)
BFPRT 算法解決的問題十分經(jīng)典,即從某n個(gè)元素的序列中選出第k大(第k小)的元素,通過巧妙的分析,BFPRT可以保證在最壞情況下仍為線性時(shí)間復(fù)雜度。該算法的思想與快速排序思想相似,當(dāng)然,為使得算法在最壞情況下,依然能達(dá)到o(n)的時(shí)間復(fù)雜度,五位算法作者做了精妙的處理。
算法步驟:
(1)將n個(gè)元素每5個(gè)一組,分成n/5(上界)組。
(2)取出每一組的中位數(shù),任意排序方法,比如插入排序。
(3)遞歸的調(diào)用selection算法查找上一步中所有中位數(shù)的中位數(shù),設(shè)為x,偶數(shù)個(gè)中位數(shù)的情況下設(shè)定為選取中間小的一個(gè)。
(4)用x來分割數(shù)組,設(shè)小于等于x的個(gè)數(shù)為k,大于x的個(gè)數(shù)即為n-k。
(5)若i==k,返回x;若ik,在大于x的元素中遞歸查找第i-k小的元素。
終止條件:n=1時(shí),返回的即是i小元素。
6、DFS(深度優(yōu)先搜索)
深度優(yōu)先搜索算法(Depth-First-Search),是搜索算法的一種。它沿著樹的深度遍歷樹的節(jié)點(diǎn),盡可能深的搜索樹的分支。當(dāng)節(jié)點(diǎn)v的所有邊都己被探尋過,搜索將回溯到發(fā)現(xiàn)節(jié)點(diǎn)v的那條邊的起始節(jié)點(diǎn)。這一過程一直進(jìn)行到已發(fā)現(xiàn)從源節(jié)點(diǎn)可達(dá)的所有節(jié)點(diǎn)為止。如果還存在未被發(fā)現(xiàn)的節(jié)點(diǎn),則選擇其中一個(gè)作為源節(jié)點(diǎn)并重復(fù)以上過程,整個(gè)進(jìn)程反復(fù)進(jìn)行直到所有節(jié)點(diǎn)都被訪問為止。DFS屬于盲目搜索。
深度優(yōu)先搜索是圖論中的經(jīng)典算法,利用深度優(yōu)先搜索算法可以產(chǎn)生目標(biāo)圖的相應(yīng)拓?fù)渑判虮恚猛負(fù)渑判虮砜梢苑奖愕慕鉀Q很多相關(guān)的圖論問題,如最大路徑問題等等。一般用堆數(shù)據(jù)結(jié)構(gòu)來輔助實(shí)現(xiàn)DFS算法。
算法步驟:
(1)訪問頂點(diǎn)v;
(2)依次從v的未被訪問的鄰接點(diǎn)出發(fā),對圖進(jìn)行深度優(yōu)先遍歷;直至圖中和v有路徑相通的頂點(diǎn)都被訪問;
(3)若此時(shí)圖中尚有頂點(diǎn)未被訪問,則從一個(gè)未被訪問的頂點(diǎn)出發(fā),重新進(jìn)行深度優(yōu)先遍歷,直到圖中所有頂點(diǎn)均被訪問過為止。
上述描述可能比較抽象,舉個(gè)實(shí)例:
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 程序員表白程序
- AI ChatGPT真要取代程序員嗎
- 我們一起來實(shí)現(xiàn)氮化鎵的可靠運(yùn)行
- 程序員的浪漫《Rice DIY設(shè)計(jì)》
- 關(guān)于嵌入式程序員的重要問題資料下載
- 一起學(xué)習(xí)5G的網(wǎng)絡(luò)架構(gòu)了資料下載
- 一起學(xué)習(xí)中斷處理程序資料下載
- 計(jì)算機(jī)系統(tǒng)一個(gè)程序員的觀點(diǎn)PDF電子書免費(fèi)下載 3次下載
- 成為一個(gè)程序員需要準(zhǔn)備那些東西
- 算法大全:助程序員走上高手之路(單片機(jī)C語言算法+機(jī)器學(xué)習(xí)算法) 425次下載
- 關(guān)于程序員的59條編程語錄詳細(xì)資料免費(fèi)下載 9次下載
- 程序員必備專用單詞快來學(xué)習(xí)吧! 22次下載
- 程序員需要學(xué)什么,微軟資深程序員學(xué)習(xí)手冊面試寶典資料 30次下載
- 程序員羊皮卷下載版(程序員必備) 0次下載
- ADO程序員指南
- 5款程序員最佳的代碼比較工具 5334次閱讀
- 怎么給全局變量起一個(gè)別名 445次閱讀
- 盤點(diǎn)Java程序員不能錯(cuò)過的7個(gè)基本框架,完美構(gòu)建復(fù)雜應(yīng)用 2980次閱讀
- 10個(gè)經(jīng)典的C語言基礎(chǔ)算法及代碼 3w次閱讀
- MIUI的這10個(gè)小設(shè)置你都知道嗎 4203次閱讀
- 程序員值得一看的9本學(xué)習(xí)算法經(jīng)典書籍 4w次閱讀
- 一文詳解機(jī)器學(xué)習(xí)工程師必知的10大算法 1696次閱讀
- 華為資深工程師:程序員與碼農(nóng)的差異在哪? 3621次閱讀
- 一個(gè)電子發(fā)燒友的程序員成長之路 6751次閱讀
- 糾正10個(gè)有關(guān)編程的常見誤區(qū) 3253次閱讀
- 最常見10大算法類型 2.3w次閱讀
- 數(shù)據(jù)顯示:中國程序員是世界上最牛的程序員 606次閱讀
- 碼農(nóng)和程序員之間就在這5個(gè)關(guān)鍵點(diǎn)! 596次閱讀
- 我們對技術(shù)的依賴有多強(qiáng)?程序員為何關(guān)注它? 984次閱讀
- 嵌入式程序員需要了解的幾個(gè)問題 1248次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費(fèi)下載
- 0.00 MB | 1491次下載 | 免費(fèi)
- 2單片機(jī)典型實(shí)例介紹
- 18.19 MB | 95次下載 | 1 積分
- 3S7-200PLC編程實(shí)例詳細(xì)資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關(guān)電源原理及各功能電路詳解
- 0.38 MB | 11次下載 | 免費(fèi)
- 6100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 7基于單片機(jī)和 SG3525的程控開關(guān)電源設(shè)計(jì)
- 0.23 MB | 4次下載 | 免費(fèi)
- 8基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
- 0.11 MB | 4次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費(fèi)
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費(fèi)
- 4LabView 8.0 專業(yè)版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費(fèi)
- 5555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33562次下載 | 免費(fèi)
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費(fèi)
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費(fèi)
- 8開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21539次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537793次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191183次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評論
查看更多