各種排序演算法的時間複雜度和空間複雜度
(英語:bubble sort)是一種簡單的排序演算法。它重複地走訪過要排序的數列,一次比較兩個元素,如果他們的順序(如從大到小、首字母從a到z)錯誤就把他們交換過來。
#include
void
bubble_sort
(int arr,
int len)}}
intmain()
;int len =
(int
)sizeof
(arr)
/sizeof
(*arr)
;printf
("sizeof *陣列名=%d\n"
,sizeof
(*arr));
bubble_sort
(arr, len)
;int i;
for(i =
0; i < len; i++
)printf
("%d "
, arr[i]);
return0;
}
選擇排序(selection sort)是一種簡單直觀的排序演算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然後,再從剩餘未排序元素中繼續尋找最小(大)元素,然後放到已排序序列的末尾。以此類推,直到所有元素均排序完畢。
//選擇排序
#include
void
selection_sort
(int arr,
int len)
int temp = arr[i]
; arr[i]
= arr[min]
; arr[min]
= temp;}}
intmain()
;int len =
(int
)sizeof
(arr)
/sizeof
(*arr)
;printf
("sizeof *陣列名=%d\n"
,sizeof
(*arr));
selection_sort
(arr, len)
;int i;
for(i =
0; i < len; i++
)printf
("%d "
, arr[i]);
return0;
}
插入排序(英語:insertion sort)是一種簡單直觀的排序演算法。它的工作原理是通過構建有序序列,對於未排序資料,在已排序序列中從後向前掃瞄,找到相應位置並插入。插入排序在實現上,通常採用in-place排序(即只需用到 的額外空間的排序),因而在從後向前掃瞄過程中,需要反覆把已排序元素逐步向後挪位,為最新元素提供插入空間。
#include
void
insertion_sort
(int arr,
int len)
arr[j]
= temp;}}
intmain()
;int len =
(int
)sizeof
(arr)
/sizeof
(*arr)
;printf
("sizeof *陣列名=%d\n"
,sizeof
(*arr));
insertion_sort
(arr, len)
;int i;
for(i =
0; i < len; i++
)printf
("%d "
, arr[i]);
return0;
}
遞迴法#include
c語言排序演算法
很多朋友是以譚浩強老師編的 c語言教程 作為學習 c語言的入門教程的。書中涉及排序問題一般都以 冒泡法 和 選擇法 實現。為了擴大視野,增加學習程式設計的興趣,我參閱了有關書籍,整理了幾種排序法,寫出來同大家共勉。高手們不要笑,這篇文章是寫給出學者的,而且我自己也是只菜鳥,雖然內容陳舊,但值得初學者...
c語言排序演算法
c語言排序演算法 非穩定的排序演算法 選擇排序 快速排序 希爾排序 堆排序 穩定的排序演算法 氣泡排序 插入排序 歸併排序和基數排序是穩定的排序演算法。讓我們先定義乙個整型陣列a n 下面用五種方法對其從小到大排序。1 冒泡法 冒泡法大家都較熟悉。其原理為從a 0 開始,依次將其和後面的元素比較,若...
C語言排序演算法
1.插入排序 一般來說,插入排序都採用in place在陣列上實現。具體演算法描述如下 從第乙個元素開始,該元素可以認為已經被排序 取出下乙個元素,在已經排序的元素序列中從後向前掃瞄 如果該元素 已排序 大於新元素,將該元素移到下一位置 重複步驟3,直到找到已排序的元素小於或者等於新元素的位置 將新...