www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 公眾號精選 > strongerHuang
[導(dǎo)讀]如果說各種編程語言是程序員的招式,那么數(shù)據(jù)結(jié)構(gòu)和算法就相當(dāng)于程序員的內(nèi)功。想寫出精煉、優(yōu)秀的代碼,不通過不斷的錘煉,是很難做到的。

編排 |?strongerHuang 微信公眾號:strongerHuang

如果說各種編程語言是程序員的招式,那么數(shù)據(jù)結(jié)構(gòu)和算法就相當(dāng)于程序員的內(nèi)功。


想寫出精煉、優(yōu)秀的代碼,不通過不斷的錘煉,是很難做到的。


一、排序算法

排序算法作為數(shù)據(jù)結(jié)構(gòu)的重要部分,系統(tǒng)地學(xué)習(xí)一下是很有必要的。


1、排序的概念

排序是計算機(jī)內(nèi)經(jīng)常進(jìn)行的一種操作,其目的是將一組“無序”的記錄序列調(diào)整為“有序”的記錄序列。


排序分為內(nèi)部排序和外部排序。


若整個排序過程不需要訪問外存便能完成,則稱此類排序問題為內(nèi)部排序。

反之,若參加排序的記錄數(shù)量很大,整個序列的排序過程不可能在內(nèi)存中完成,則稱此類排序問題為外部排序。


2、排序分類

八大排序算法均屬于內(nèi)部排序。如果按照策略來分類,大致可分為:交換排序、插入排序、選擇排序、歸并排序和基數(shù)排序。如下圖所示:


3、算法分析 A.插入排序 *直接插入排序 *希爾排序 B.選擇排序 *簡單選擇排序 *堆排序 C.交換排序 *冒泡排序 *快速排序 D.歸并排序 E.基數(shù)排序 不穩(wěn)定排序:簡單選擇排序,快速排序,希爾排序,堆排序 穩(wěn)定排序:冒泡排序,直接插入排序,歸并排序,基數(shù)排序


進(jìn)一步描述八大排序:

①插入排序

將第一個和第二個元素排好序,然后將第3個元素插入到已經(jīng)排好序的元素中,依次類推(插入排序最好的情況就是數(shù)組已經(jīng)有序了)。


②希爾排序

因為插入排序每次只能操作一個元素,效率低。元素個數(shù)N,取奇數(shù)k=N/2,將下標(biāo)差值為k的數(shù)分為一組(一組元素個數(shù)看總元素個數(shù)決定),在組內(nèi)構(gòu)成有序序列,再取k=k/2,將下標(biāo)差值為k的數(shù)分為一組,構(gòu)成有序序列,直到k=1,然后再進(jìn)行直接插入排序。


③簡單選擇排序

選出最小的數(shù)和第一個數(shù)交換,再在剩余的數(shù)中又選擇最小的和第二個數(shù)交換,依次類推。


④堆排序

以升序排序為例,利用小根堆的性質(zhì)(堆頂元素最小)不斷輸出最小元素,直到堆中沒有元素

1.構(gòu)建小根堆

2.輸出堆頂元素

3.將堆低元素放一個到堆頂,再重新構(gòu)造成小根堆,再輸出堆頂元素,以此類推。


⑤冒泡排序

改進(jìn)1:如果某次冒泡不存在數(shù)據(jù)交換,則說明已經(jīng)排序好了,可以直接退出排序

改進(jìn)2:頭尾進(jìn)行冒泡,每次把最大的沉底,最小的浮上去,兩邊往中間靠1


⑥快速排序

選擇一個基準(zhǔn)元素,比基準(zhǔn)元素小的放基準(zhǔn)元素的前面,比基準(zhǔn)元素大的放基準(zhǔn)元素的后面,這種動作叫分區(qū),每次分區(qū)都把一個數(shù)列分成了兩部分,每次分區(qū)都使得一個數(shù)字有序,然后將基準(zhǔn)元素前面部分和后面部分繼續(xù)分區(qū),一直分區(qū)直到分區(qū)的區(qū)間中只有一個元素的時候,一個元素的序列肯定是有序的嘛,所以最后一個升序的序列就完成啦。


⑦歸并排序

將一個無序的數(shù)列一直一分為二,直到分到序列中只有一個數(shù)的時候,這個序列肯定是有序的,因為只有一個數(shù),然后將兩個只含有一個數(shù)字的序列合并為含有兩個數(shù)字的有序序列,這樣一直進(jìn)行下去,最后就變成了一個大的有序數(shù)列


基數(shù)排序

找到最大的數(shù),開個比最大的數(shù)大一點的數(shù)組,遍歷每個元素,某個元素為k,則a[k]++,最好遍歷數(shù)組a,a[k]等于多少就輸出多少個k。只能處理整型數(shù)。


三、詳解八大排序算法

1.插入排序

直接插入排序的核心思想就是:將數(shù)組中的所有元素依次跟前面已經(jīng)排好的元素相比較,如果選擇的元素比已排序的元素小,則交換,直到全部元素都比較過。


因此,從上面的描述中我們可以發(fā)現(xiàn),直接插入排序可以用兩個循環(huán)完成:

第一層循環(huán):遍歷待比較的所有數(shù)組元素。

第二層循環(huán):將本輪選擇的元素(selected)與已經(jīng)排好序的元素(ordered)相比較。如果:selected > ordered,那么將二者交換。


2.希爾排序

希爾排序,也稱遞減增量排序算法,是插入排序的一種更高效的改進(jìn)版本。但希爾排序是非穩(wěn)定排序算法。


希爾排序的基本思想是:先將整個待排序的記錄序列分割成為若干子序列分別進(jìn)行直接插入排序,待整個序列中的記錄“基本有序”時,再對全體記錄進(jìn)行依次直接插入排序。


算法步驟:

a.選擇一個增量序列t1,t2,…,tk,其中ti>tj,tk=1;


b.按增量序列個數(shù)k,對序列進(jìn)行k 趟排序;


c.每趟排序,根據(jù)對應(yīng)的增量ti,將待排序列分割成若干長度為m 的子序列,分別對各子表進(jìn)行直接插入排序。僅增量因子為1 時,整個序列作為一個表來處理,表長度即為整個序列的長度。


3.簡單選擇排序

簡單選擇排序的實現(xiàn)思想:比較+交換


從待排序序列中,找到關(guān)鍵字最小的元素;


如果最小元素不是待排序序列的第一個元素,將其和第一個元素互換;


從余下的 N - 1 個元素中,找出關(guān)鍵字最小的元素,重復(fù)(1)、(2)步,直到排序結(jié)束。因此我們可以發(fā)現(xiàn),簡單選擇排序也是通過兩層循環(huán)實現(xiàn)。第一層循環(huán):依次遍歷序列當(dāng)中的每一個元素 第二層循環(huán):將遍歷得到的當(dāng)前元素依次與余下的元素進(jìn)行比較,符合最小元素的條件,則交換。


4.堆排序

堆:本質(zhì)是一種數(shù)組對象。特別重要的一點性質(zhì):任意的葉子節(jié)點小于(或大于)它所有的父節(jié)點。對此,又分為大頂堆和小頂堆:

大頂堆要求節(jié)點的元素都要大于其孩子。

小頂堆要求節(jié)點元素都小于其左右孩子。

兩者對左右孩子的大小關(guān)系不做任何要求。


利用堆排序,就是基于大頂堆或者小頂堆的一種排序方法。下面,我們通過大頂堆來實現(xiàn)。


基本思想:堆排序可以按照以下步驟來完成:

a.首先將序列構(gòu)建稱為大頂堆;(這樣滿足了大頂堆那條性質(zhì):位于根節(jié)點的元素一定是當(dāng)前序列的最大值)。


b.取出當(dāng)前大頂堆的根節(jié)點,將其與序列末尾元素進(jìn)行交換;(此時:序列末尾的元素為已排序的最大值;由于交換了元素,當(dāng)前位于根節(jié)點的堆并不一定滿足大頂堆的性質(zhì))。


c.對交換后的n-1個序列元素進(jìn)行調(diào)整,使其滿足大頂堆的性質(zhì)。


d.重復(fù)2.3步驟,直至堆中只有1個元素為止。


5.冒泡排序

算法思想:冒泡遍歷所有的數(shù)據(jù),每次對相鄰元素進(jìn)行兩兩比較,如果順序和預(yù)先規(guī)定的順序不一致,則進(jìn)行位置交換;這樣一次遍歷會將最大或最小的數(shù)據(jù)上浮到頂端,之后再重復(fù)同樣的操作,直到所有的數(shù)據(jù)有序。這個算法的名字由來是因為越大的元素會經(jīng)由交換慢慢“浮”到數(shù)列的頂端。


6.快速排序

快速排序是由東尼·霍爾所發(fā)展的一種排序算法。在平均狀況下,排序 n 個項目要Ο(n logn)次比較。在最壞狀況下則需要Ο(n2)次比較,但這種狀況并不常見。事實上,快速排序通常明顯比其他Ο(n log n) 算法更快,因為它的內(nèi)部循環(huán)(inner loop)可以在大部分的架構(gòu)上很有效率地被實現(xiàn)出來


快速排序使用分治法(Divide and conquer)策略來把一個串行(list)分為兩個子串行(sub-lists)。


算法步驟:

a.從數(shù)列中挑出一個元素,稱為 “基準(zhǔn)”(pivot)。


b.重新排序數(shù)列,所有元素比基準(zhǔn)值小的擺放在基準(zhǔn)前面,所有元素比基準(zhǔn)值大的擺在基準(zhǔn)的后面(相同的數(shù)可以到任一邊)。在這個分區(qū)退出之后,該基準(zhǔn)就處于數(shù)列的中間位置。這個稱為分區(qū)(partition)操作。


c.遞歸地(recursive)把小于基準(zhǔn)值元素的子數(shù)列和大于基準(zhǔn)值元素的子數(shù)列排序。


遞歸的最底部情形,是數(shù)列的大小是零或一,也就是永遠(yuǎn)都已經(jīng)被排序好了。雖然一直遞歸下去,但是這個算法總會退出,因為在每次的迭代(iteration)中,它至少會把一個元素擺到它最后的位置去。


7.歸并排序 歸并排序(Merge sort)是建立在歸并操作上的一種有效的排序算法。該算法是采用分治法(Divide and Conquer)的一個非常典型的應(yīng)用。
算法步驟: a. 申請空間,使其大小為兩個已經(jīng)排序序列之和,該空間用來存放合并后的序列;
b. 設(shè)定兩個指針,最初位置分別為兩個已經(jīng)排序序列的起始位置;
c. 比較兩個指針?biāo)赶虻脑?,選擇相對小的元素放入到合并空間,并移動指針到下一位置;
d. 重復(fù)步驟3直到某一指針達(dá)到序列尾;
e. 將另一序列剩下的所有元素直接復(fù)制到合并序列尾。

8.基數(shù)排序

基數(shù)排序:通過序列中各個元素的值,對排序的N個元素進(jìn)行若干趟的“分配”與“收集”來實現(xiàn)排序。


分配:我們將L[i]中的元素取出,首先確定其個位上的數(shù)字,根據(jù)該數(shù)字分配到與之序號相同的桶中 。


收集:當(dāng)序列中所有的元素都分配到對應(yīng)的桶中,再按照順序依次將桶中的元素收集形成新的一個待排序列L[ ] 。


對新形成的序列L[ ]重復(fù)執(zhí)行分配和收集元素中的十位、百位...直到分配完該序列中的最高位,則排序結(jié)束。


好了,本文就分享到這里,本文主要講解原理,不同編程語言實現(xiàn)方法不同,后面有機(jī)會再給大家分享具體實現(xiàn)方法。


------------ END ------------

推薦閱讀:
C語言實現(xiàn)面向?qū)ο蟮脑?/strong>
C/C++代碼規(guī)范注釋有哪些講究?
Embedded Studio中使用ST-Link調(diào)試教程
關(guān) 微信公眾號『strongerHuang』,后臺回復(fù)“1024”查看更多內(nèi)容,回復(fù)“加群”按規(guī)則加入技術(shù)交流群。


長按前往圖中包含的公眾號關(guān)注


點擊“ 閱讀原文 ”查看更多分享,歡迎點分享、收藏、點贊、在看。

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉