精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

C語言動圖演示十大經典排序算法(含代碼)

jf_BxU6dNQb ? 來源:混說Linux ? 2023-01-29 11:34 ? 次閱讀

本文將通過動態(tài)演示+代碼的形式系統地總結十大經典排序算法

排序算法

算法分類

十種常見排序算法可以分為兩大類:

比較類排序:通過比較來決定元素間的相對次序,由于其時間復雜度不能突破O(nlogn),因此也稱為非線性時間比較類排序。

非比較類排序:不通過比較來決定元素間的相對次序,它可以突破基于比較排序的時間下界,以線性時間運行,因此也稱為線性時間非比較類排序。

f8fcf3d4-96d9-11ed-bfe3-dac502259ad0.png

算法復雜度

排序算法 平均時間復雜度 最差時間復雜度 空間復雜度 數據對象穩(wěn)定性
冒泡排序 O(n2) O(n2) O(1) 穩(wěn)定
選擇排序 O(n2) O(n2) O(1) 數組不穩(wěn)定、鏈表穩(wěn)定
插入排序 O(n2) O(n2) O(1) 穩(wěn)定
快速排序 O(n*log2n) O(n2) O(log2n) 不穩(wěn)定
堆排序 O(n*log2n) O(n*log2n) O(1) 不穩(wěn)定
歸并排序 O(n*log2n) O(n*log2n) O(n) 穩(wěn)定
希爾排序 O(n*log2n) O(n2) O(1) 不穩(wěn)定
計數排序 O(n+m) O(n+m) O(n+m) 穩(wěn)定
桶排序 O(n) O(n) O(m) 穩(wěn)定
基數排序 O(k*n) O(n2) 穩(wěn)定

1. 冒泡排序

算法思想:

比較相鄰的元素。如果第一個比第二個大,就交換它們兩個

對每一對相鄰元素作同樣的工作,從開始第一對到結尾的最后一對,這樣在最后的元素應該會是最大的數;

針對所有的元素重復以上的步驟,除了最后一個;

重復步驟1~3,直到排序完成。

f91e68e8-96d9-11ed-bfe3-dac502259ad0.gif

代碼:

voidbubbleSort(inta[],intn)
{
for(inti=0;ia[j+1])
{
inttmp=a[j];//交換
a[j]=a[j+1];
a[j+1]=tmp;
}
}
}
}

2. 選擇排序

算法思想:

在未排序序列中找到最小(大)元素,存放到排序序列的起始位置

從剩余未排序元素中繼續(xù)尋找最小(大)元素,然后放到已排序序列的末

以此類推,直到所有元素均排序完畢

f948465e-96d9-11ed-bfe3-dac502259ad0.gif

代碼:

voidselectionSort(intarr[],intn){
intminIndex,temp;
for(inti=0;i

3. 插入排序

算法思想:

從第一個元素開始,該元素可以認為已經被排序;

取出下一個元素,在已經排序的元素序列中從后向前掃描;

如果該元素(已排序)大于新元素,將該元素移到下一位置;

重復步驟3,直到找到已排序的元素小于或者等于新元素的位置;

將新元素插入到該位置后;

重復步驟2~5。

f961bf62-96d9-11ed-bfe3-dac502259ad0.gif

代碼:

voidprint(inta[],intn,inti){
cout<

算法分析:

插入排序在實現上,通常采用in-place排序(即只需用到O(1)的額外空間的排序),因而在從后向前掃描過程中,需要反復把已排序元素逐步向后挪位,為最新元素提供插入空間。

4.快速排序

快速排序的基本思想是通過一趟排序將待排記錄分隔成獨立的兩部分,其中一部分記錄的關鍵字均比另一部分的關鍵字小,則可分別對這兩部分記錄繼續(xù)進行排序,以達到整個序列有序。

算法思想:

選取第一個數為基準

將比基準小的數交換到前面,比基準大的數交換到后面

遞歸地(recursive)把小于基準值元素的子數列和大于基準值元素的子數列排序

f99b9db8-96d9-11ed-bfe3-dac502259ad0.gif

代碼:

voidQuickSort(vector&v,intlow,inthigh){
if(low>=high)//結束標志
return;
intfirst=low;//低位下標
intlast=high;//高位下標
intkey=v[first];//設第一個為基準

while(first=key)
last--;
if(first

5.堆排序

堆排序(Heapsort)是指利用堆這種數據結構所設計的一種排序算法。堆積是一個近似完全二叉樹的結構,并同時滿足堆積的性質:即子節(jié)點的鍵值或索引總是小于(或者大于)它的父節(jié)點。

算法思想:

將初始待排序關鍵字序列(R1,R2….Rn)構建成大頂堆,此堆為初始的無序區(qū);

將堆頂元素R[1]與最后一個元素R[n]交換,此時得到新的無序區(qū)(R1,R2,……Rn-1)和新的有序區(qū)(Rn),且滿足R[1,2…n-1]<=R[n];

由于交換后新的堆頂R[1]可能違反堆的性質,因此需要對當前無序區(qū)(R1,R2,……Rn-1)調整為新堆,然后再次將R[1]與無序區(qū)最后一個元素交換,得到新的無序區(qū)(R1,R2….Rn-2)和新的有序區(qū)(Rn-1,Rn)。不斷重復此過程直到有序區(qū)的元素個數為n-1,則整個排序過程完成。

代碼:

#include
#include
usingnamespacestd;

//堆排序:(最大堆,有序區(qū))。從堆頂把根卸出來放在有序區(qū)之前,再恢復堆。

voidmax_heapify(intarr[],intstart,intend){
//建立父節(jié)點指標和子節(jié)點指標
intdad=start;
intson=dad*2+1;
while(son<=?end)?{?//若子節(jié)點在范圍內才做比較
????????if?(son?+?1?<=?end?&&?arr[son]?arr[son])//如果父節(jié)點大于子節(jié)點代表調整完成,直接跳出函數
return;
else{//否則交換父子內容再繼續(xù)子節(jié)點與孫節(jié)點比較
swap(arr[dad],arr[son]);
dad=son;
son=dad*2+1;
}
}
}

voidheap_sort(intarr[],intlen){
//初始化,i從最后一個父節(jié)點開始調整
for(inti=len/2-1;i>=0;i--)
max_heapify(arr,i,len-1);
//先將第一個元素和已經排好的元素前一位做交換,再從新調整(剛調整的元素之前的元素),直到排序完成
for(inti=len-1;i>0;i--){
swap(arr[0],arr[i]);
max_heapify(arr,0,i-1);
}
}

intmain(){
intarr[]={3,5,3,0,8,6,1,5,8,6,2,4,9,4,7,0,1,8,9,7,3,1,2,5,9,7,4,0,2,6};
intlen=(int)sizeof(arr)/sizeof(*arr);
heap_sort(arr,len);
for(inti=0;i

6. 歸并排序

歸并排序是建立在歸并操作上的一種有效的排序算法。該算法是采用分治法(Divide and Conquer)的一個非常典型的應用。將已有序的子序列合并,得到完全有序的序列;即先使每個子序列有序,再使子序列段間有序。若將兩個有序表合并成一個有序表,稱為2-路歸并。

算法思想:

把長度為n的輸入序列分成兩個長度為n/2的子序列;

對這兩個子序列分別采用歸并排序;

將兩個排序好的子序列合并成一個最終的排序序列。

f9b598da-96d9-11ed-bfe3-dac502259ad0.gif

代碼:

voidprint(inta[],intn){
for(intj=0;j

7. 希爾排序

1959年Shell發(fā)明,第一個突破O(n2)的排序算法,是簡單插入排序的改進版。它與插入排序的不同之處在于,它會優(yōu)先比較距離較遠的元素。希爾排序又叫縮小增量排序。

算法思想:

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

按增量序列個數k,對序列進行k 趟排序;

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

fa6ef032-96d9-11ed-bfe3-dac502259ad0.gif

代碼:

voidshell_sort(Tarray[],intlength){
inth=1;
while(h=1){
for(inti=h;i=h&&array[j]

8 計數排序

計數排序不是基于比較的排序算法,其核心在于將輸入的數據值轉化為鍵存儲在額外開辟的數組空間中。作為一種線性時間復雜度的排序,計數排序要求輸入的數據必須是有確定范圍的整數。

算法思想:

找出待排序的數組中最大和最小的元素;

統計數組中每個值為i的元素出現的次數,存入數組C的第i項;

對所有的計數累加(從C中的第一個元素開始,每一項和前一項相加);

反向填充目標數組:將每個元素i放在新數組的第C(i)項,每放一個元素就將C(i)減去1。

fa8e68cc-96d9-11ed-bfe3-dac502259ad0.gif

代碼:

#include
#include
#include

usingnamespacestd;

//計數排序
voidCountSort(vector&vecRaw,vector&vecObj)
{
//確保待排序容器非空
if(vecRaw.size()==0)
return;

//使用vecRaw的最大值+1作為計數容器countVec的大小
intvecCountLength=(*max_element(begin(vecRaw),end(vecRaw)))+1;
vectorvecCount(vecCountLength,0);

//統計每個鍵值出現的次數
for(inti=0;i0;i--)//此處逆序是為了保持相同鍵值的穩(wěn)定性
vecObj[--vecCount[vecRaw[i-1]]]=vecRaw[i-1];
}

intmain()
{
vectorvecRaw={0,5,7,9,6,3,4,5,2,8,6,9,2,1};
vectorvecObj(vecRaw.size(),0);

CountSort(vecRaw,vecObj);

for(inti=0;i

9 桶排序

將值為i的元素放入i號桶,最后依次把桶里的元素倒出來。

算法思想:

設置一個定量的數組當作空桶子。

尋訪序列,并且把項目一個一個放到對應的桶子去。

對每個不是空的桶子進行排序。

從不是空的桶子里把項目再放回原來的序列中。

fac02736-96d9-11ed-bfe3-dac502259ad0.gif

代碼:

voidBucket_Sort(inta[],intn,intmax){
inti,j=0;
int*buckets=(int*)malloc((max+1)*sizeof(int));
//將buckets中的所有數據都初始化為0
memset(buckets,0,(max+1)*sizeof(int));
//1.計數
for(i=0;i0){
a[j++]=i;
}
}
}

intmain(){
intarr[]={9,5,1,6,2,3,0,4,8,7};
Bucket_Sort(arr,10,9);
for(inti=0;i

10 基數排序

一種多關鍵字的排序算法,可用桶排序實現。

算法思想:

取得數組中的最大數,并取得位數;

arr為原始數組,從最低位開始取每個位組成radix數組;

對radix進行計數排序(利用計數排序適用于小范圍數的特點)

fb06dd8e-96d9-11ed-bfe3-dac502259ad0.gif

代碼:

intmaxbit(intdata[],intn)//輔助函數,求數據的最大位數
{
intmaxData=data[0];///=p)
{
//p*=10;//Maybeoverflow
maxData/=10;
++d;
}
returnd;
/*intd=1;//保存最大的位數
intp=10;
for(inti=0;i=p)
{
p*=10;
++d;
}
}
returnd;*/
}
voidradixsort(intdata[],intn)//基數排序
{
intd=maxbit(data,n);
int*tmp=newint[n];
int*count=newint[10];//計數器
inti,j,k;
intradix=1;
for(i=1;i<=?d;?i++)?//進行d次排序
????{
????????for(j?=?0;?j?=0;j--)//將所有桶中記錄依次收集到tmp中
{
k=(data[j]/radix)%10;
tmp[count[k]-1]=data[j];
count[k]--;
}
for(j=0;j

審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯系本站處理。 舉報投訴
  • 算法
    +關注

    關注

    23

    文章

    4599

    瀏覽量

    92641
  • C語言
    +關注

    關注

    180

    文章

    7598

    瀏覽量

    136184
  • 代碼
    +關注

    關注

    30

    文章

    4747

    瀏覽量

    68348
  • 數據結構
    +關注

    關注

    3

    文章

    573

    瀏覽量

    40092
  • 排序算法
    +關注

    關注

    0

    文章

    52

    瀏覽量

    10051

原文標題:C語言 | 動圖演示十大經典排序算法(含代碼)

文章出處:【微信號:混說Linux,微信公眾號:混說Linux】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    展示C語言十大經典排序算法

    以前也零零碎碎發(fā)過一些排序算法,但排版都不太好,又重新整理一次,排序算法是數據結構的重要部分,系統地學習很有必要。
    發(fā)表于 11-08 09:45 ?574次閱讀

    C語言經典排序算法總結

    本文將通過動態(tài)演示+代碼的形式系統地總結十大經典排序算法
    發(fā)表于 06-05 10:56 ?520次閱讀
    <b class='flag-5'>C</b><b class='flag-5'>語言</b><b class='flag-5'>經典</b><b class='flag-5'>排序</b><b class='flag-5'>算法</b>總結

    C語言實現十大經典排序算法

    比較類排序:通過比較來決定元素間的相對次序,由于其時間復雜度不能突破O(nlogn),因此也稱為非線性時間比較類排序
    發(fā)表于 06-25 10:23 ?350次閱讀
    <b class='flag-5'>C</b><b class='flag-5'>語言</b>實現<b class='flag-5'>十大經典</b><b class='flag-5'>排序</b><b class='flag-5'>算法</b>

    十大排序算法總結

    排序算法是最經典算法知識。因為其實現代碼短,應該廣,在面試中經常會問到排序
    的頭像 發(fā)表于 12-20 10:39 ?1082次閱讀

    C語言十大濾波算法

    C語言十大濾波算法
    發(fā)表于 08-15 18:41

    經典算法大全(51個C語言算法+單片機常用算法+機器學十大算法

    流程、偽代碼等來描述算法。 本經典算法研究系列,如今己寫了22篇,13個算法,包括
    發(fā)表于 10-23 14:31

    數據挖掘十大經典算法,你都知道哪些!

    的所有需求。而這三類里又包含許多經典算法。而今天,小編就給大家介紹下數據挖掘中最經典十大算法,希望它對你有所幫助。一、 分類決策樹
    發(fā)表于 11-06 17:02

    電池管理中的十大經典理論

    電池管理中的十大經典理論 1、彼得原理      每個組織都是由各種不同的職位、等級或階層的排列所組成,每個人都隸屬于
    發(fā)表于 11-06 15:43 ?792次閱讀

    數學建模十大經典算法

    電子專業(yè)單片機相關知識學習教材資料——數學建模十大經典算法
    發(fā)表于 08-08 18:20 ?0次下載

    10個經典C語言面試基礎算法代碼

    10個經典C語言面試基礎算法代碼
    的頭像 發(fā)表于 01-16 11:09 ?2825次閱讀

    演示C語言10大經典排序算法(代碼)

    快速排序的基本思想是通過一趟排序將待排記錄分隔成獨立的兩部分,其中一部分記錄的關鍵字均比另一部分的關鍵字小,則可分別對這兩部分記錄繼續(xù)進行排序,以達到整個序列有序。
    的頭像 發(fā)表于 02-02 15:41 ?2685次閱讀

    演示C語言10大經典排序算法(代碼)

    本文將通過 動態(tài)演示+代碼 的形式系統地總結十大經典排序算法排序
    的頭像 發(fā)表于 02-07 01:24 ?697次閱讀

    用Python實現十大經典排序算法(附)

    冒泡排序(Bubble Sort)也是一種簡單直觀的排序算法。它重復地走訪過要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數列的工作是重復地進行直到沒有再需要
    的頭像 發(fā)表于 03-13 09:29 ?1913次閱讀

    常見排序算法分類

    本文將通過動態(tài)演示+代碼的形式系統地總結十大經典排序算法排序
    的頭像 發(fā)表于 06-22 14:49 ?888次閱讀
    常見<b class='flag-5'>排序</b><b class='flag-5'>算法</b>分類

    單片機ADC,十大C語言濾波算法

    單片機ADC,十大C語言濾波算法
    的頭像 發(fā)表于 10-24 15:53 ?1171次閱讀