資料介紹
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é)點。這一過程一直進行到已發(fā)現(xiàn)從源節(jié)點可達(dá)的所有節(jié)點為止。如果還存在未被發(fā)現(xiàn)的節(jié)點,則選擇其中一個作為源節(jié)點并重復(fù)以上過程,整個進程反復(fù)進行直到所有節(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ā),對圖進行深度優(yōu)先遍歷;直至圖中和v有路徑相通的頂點都被訪問;
(3)若此時圖中尚有頂點未被訪問,則從一個未被訪問的頂點出發(fā),重新進行深度優(yōu)先遍歷,直到圖中所有頂點均被訪問過為止。
上述描述可能比較抽象,舉個實例:
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 程序員表白程序
- AI ChatGPT真要取代程序員嗎
- 我們一起來實現(xiàn)氮化鎵的可靠運行
- 程序員的浪漫《Rice DIY設(shè)計》
- 關(guān)于嵌入式程序員的重要問題資料下載
- 一起學(xué)習(xí)5G的網(wǎng)絡(luò)架構(gòu)了資料下載
- 一起學(xué)習(xí)中斷處理程序資料下載
- 計算機系統(tǒng)一個程序員的觀點PDF電子書免費下載 3次下載
- 成為一個程序員需要準(zhǔn)備那些東西
- 算法大全:助程序員走上高手之路(單片機C語言算法+機器學(xué)習(xí)算法) 426次下載
- 關(guān)于程序員的59條編程語錄詳細(xì)資料免費下載 9次下載
- 程序員必備專用單詞快來學(xué)習(xí)吧! 25次下載
- 程序員需要學(xué)什么,微軟資深程序員學(xué)習(xí)手冊面試寶典資料 30次下載
- 程序員羊皮卷下載版(程序員必備) 0次下載
- ADO程序員指南
- 5款程序員最佳的代碼比較工具 6.9k次閱讀
- 怎么給全局變量起一個別名 1.1k次閱讀
- 盤點Java程序員不能錯過的7個基本框架,完美構(gòu)建復(fù)雜應(yīng)用 3.7k次閱讀
- 10個經(jīng)典的C語言基礎(chǔ)算法及代碼 3.1w次閱讀
- MIUI的這10個小設(shè)置你都知道嗎 4.9k次閱讀
- 程序員值得一看的9本學(xué)習(xí)算法經(jīng)典書籍 4.1w次閱讀
- 一文詳解機器學(xué)習(xí)工程師必知的10大算法 2.3k次閱讀
- 華為資深工程師:程序員與碼農(nóng)的差異在哪? 4.1k次閱讀
- 一個電子發(fā)燒友的程序員成長之路 7.5k次閱讀
- 糾正10個有關(guān)編程的常見誤區(qū) 3.8k次閱讀
- 最常見10大算法類型 2.5w次閱讀
- 數(shù)據(jù)顯示:中國程序員是世界上最牛的程序員 812次閱讀
- 碼農(nóng)和程序員之間就在這5個關(guān)鍵點! 842次閱讀
- 我們對技術(shù)的依賴有多強?程序員為何關(guān)注它? 1.2k次閱讀
- 嵌入式程序員需要了解的幾個問題 1.5k次閱讀
下載排行
本周
- 1MDD品牌三極管MMBT3906數(shù)據(jù)手冊
- 2.33 MB | 次下載 | 免費
- 2MDD品牌三極管S9012數(shù)據(jù)手冊
- 2.62 MB | 次下載 | 免費
- 3聯(lián)想flex2-14D/15D說明書
- 4.92 MB | 次下載 | 免費
- 4收音環(huán)繞擴音機 AVR-1507手冊
- 2.50 MB | 次下載 | 免費
- 524Pin Type-C連接器設(shè)計報告
- 1.06 MB | 次下載 | 免費
- 6新一代網(wǎng)絡(luò)可視化(NPB 2.0)
- 3.40 MB | 次下載 | 免費
- 7MS1000TA 超聲波測量模擬前端芯片技術(shù)手冊
- 0.60 MB | 次下載 | 免費
- 8MS1022高精度時間測量(TDC)電路數(shù)據(jù)手冊
- 1.81 MB | 次下載 | 免費
本月
- 1愛華AIWA HS-J202維修手冊
- 3.34 MB | 37次下載 | 免費
- 2PC5502負(fù)載均流控制電路數(shù)據(jù)手冊
- 1.63 MB | 23次下載 | 免費
- 3NB-IoT芯片廠商的資料說明
- 0.31 MB | 22次下載 | 1 積分
- 4H110主板CPU PWM芯片ISL95858HRZ-T核心供電電路圖資料
- 0.63 MB | 6次下載 | 1 積分
- 5UWB653Pro USB口測距通信定位模塊規(guī)格書
- 838.47 KB | 5次下載 | 免費
- 6技嘉H110主板IT8628E_BX IO電路圖資料
- 2.61 MB | 4次下載 | 1 積分
- 7蘇泊爾DCL6907(即CHK-S007)單芯片電磁爐原理圖資料
- 0.04 MB | 4次下載 | 1 積分
- 8100W準(zhǔn)諧振反激式恒流電源電路圖資料
- 0.09 MB | 2次下載 | 1 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191439次下載 | 10 積分
- 5十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183353次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81602次下載 | 10 積分
- 7Keil工具MDK-Arm免費下載
- 0.02 MB | 73822次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發(fā)燒友App





創(chuàng)作
發(fā)文章
發(fā)帖
提問
發(fā)資料
發(fā)視頻
上傳資料賺積分
評論