王道資料結構 (18) 快速排序

2022-06-16 12:42:09 字數 1484 閱讀 8269

**:

#include #include 

#define n 6

int partition(int arr, int low, int

high)

arr[low] =key;

return

low;

}void quick_sort(int arr, int start, int

end)

return;}

int main(void

); printf(

"排序前 \n");

for(i=0;i)

printf(

"%d\t

",arr[i]);

quick_sort(arr,

0,n-1

); printf(

"\n 排序後 \n");

for(i=0; i)

printf(

"%d\t

", arr[i]);

printf ("\n

");system(

"pause");

return0;

}

執行結果:

排序前

32 12 7 78 23 45

排序後7 12 23 32 45 78

在上面的**中,根據前面介紹的步驟一步步實現了快速排序演算法。接下來通過示意圖來演示第一次劃分操作。

在第一次劃分操作中,先進行初始設定,key的值是進行劃分的基準,其值為要劃分數 組的第乙個元素值,在上面的排序序列中為第乙個元素值32,同時將low設定為要排序陣列中第乙個元素的下標,第一次排序操作時其值為0,將high設定為要排序序列最後乙個 元素的下標,在上面的排序序列中其第一次取值為5。先將下標為high的陣列元素與key進行比較,由於該元素值大於key,因此high向左移動乙個位置繼續掃瞄。由於接下來的值為 23,小於key的值,因此將23賦值給下標為low所指向的陣列元素。接下來將low右移一 個位置,將low所指向的陣列元素的值與key進行比較,由幹接下來的12、7都小於key, 因此low繼續右移掃瞄,直至下標low所指向的陣列元素的值為78即大於key為止,將78賦值給下標為high所指向的陣列元素,同時將high左移乙個位置。接下來由於low不再小於high,劃分結束。需要注意的是,在進行劃分的過程中,都是將掃瞄的值與key的值進行對比,如果小於key,那麼將該值賦值給陣列中的另外乙個元素,而該元素的值並沒有改變。 從圖中可以看出這一點,所以需要在劃分的最後將作為劃分基準的key值賦值給下標為 pos的陣列元素,這個元素不再參與接下來的劃分操作。

第一次劃分操作

第一輪劃分結束後,得到了左右兩部分序列a[0]、a[1]、a[2]和a[4]、a[5],繼續進 行劃分,即對毎輪劃分後得到的兩部分序列繼續劃分,直至得到有序序列為止。

資料結構 排序 快速排序

對序列 47,31,83,91,57,18,96,16 進行快速排序 首元素為基準 第二趟排序結果是 正確答案 b 你的答案 c 錯誤 18 31 16 47 57 91 96 83 16 31 18 47 57 91 96 83 16 18 31 47 57 91 96 83 16 18 31 4...

資料結構 排序 快速排序

快速排序在平均情況下是效果最好的排序演算法 每趟子表的排序都是從兩頭向中間交替逼近,接下來舉乙個例子 sorry,上面這個圖的6和5的位置畫反啦,快速排序全域性有序,一趟排序便可以確定基準值的最終位置 類別排序方法 最好時間 最壞時間 平均時間 空間複雜度 穩定性序列特徵 適用於插入排序 直接插入排...

資料結構排序 快速排序

快速排序是對氣泡排序的改進,它的基本思想是通過一趟排序將資料分成兩部分,一部分中的資料都比另一部分中的資料小,再對這兩部分中的資料再排序,直到整個序列有序,如下圖所示。快排的遞迴實現 1 include 2 include 3 4intn 5 6 7 分割使樞軸記錄的左邊元素比右邊元素小8 9int...