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