C/C++實(shí)現(xiàn)快速排序算法的兩種方式實(shí)例
介紹
快速排序是對冒泡排序算法的一種改進(jìn),快速排序算法通過多次比較和交換來實(shí)現(xiàn)排序。
流程如下

(圖片來自百度)
實(shí)現(xiàn)
以下有兩種實(shí)現(xiàn)方式,說是兩種,其實(shí)就是在交換元素時具體細(xì)節(jié)上有點(diǎn)不同罷了。
方式一
int Partition(int A[],int low,int high){
int pivot=A[low];//第一個元素作為基準(zhǔn)
while(low<high){
while(low<high && A[high]>=pivot) high--;
A[low]=A[high];
while(low<high && A[low]<=pivot) low++;
A[high]=A[low];
}
A[low]=pivot;
return low;
}
void QuickSort(int A[],int low,int high){
if(low<high){
int pivotpos=Partition(A,low,high);
QuickSort(A,low,pivotpos-1);
QuickSort(A,pivotpos+1,high);
}
}
該方式,先把基準(zhǔn)元素保存起來
如下圖數(shù)組,把49看作基準(zhǔn)元素,先移動high指針,當(dāng)指向27時退出while循環(huán),把27放到low位置


這時候,high位置就空出來一個,那么讓low移動,移動到下圖所示時,65>49,退出while循環(huán),再將65放到high位置

這樣low這個位置又空出來了,再移動high,如此反復(fù)。

最后得到如下圖的情況:

這樣我們就按照“49”,把數(shù)組分為了左右兩部分。
對左右兩部分分別進(jìn)行上述操作即可。

方式二
void Quick_sort(int left,int right,int arr[]){
if(left>=right)return;
int i,j,base,temp;
i=left,j=right;
base=arr[left];
while(i<j){
while(arr[j]>=base && i<j)j--;
while(arr[i]<=base && i<j)i++;
if(i<j){
temp=arr[i];
arr[i]=arr[j];
arr[j]=temp;
}
}
arr[left]=arr[i];
arr[i]=base;
Quick_sort(left,i-1,arr);
Quick_sort(i+1,right,arr);
}
對于第二種方式,看下圖即可很好理解。
高低指針不是輪流替換空余位置,而是同時找到不符合的元素,然后交換二者。
最后,高低指針相遇,再把基準(zhǔn)元素與相遇位置上的元素交換即可。
(以下圖片來自網(wǎng)絡(luò),侵刪)




總結(jié)
到此這篇關(guān)于C/C++實(shí)現(xiàn)快速排序的兩種方式的文章就介紹到這了,更多相關(guān)C/C++實(shí)現(xiàn)快速排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
linux下c語言中隱藏進(jìn)程命令行參數(shù)(例如輸入密碼等高危操作)
啟動程序很多時候用命令行參數(shù)可以很方便,做到簡化一些配置,但是輸入用戶名密碼等操作,如果通過進(jìn)程查看工具直接看到密碼就太不安全了,這里就為大家分享一下方法2021-01-01
C++begin和end運(yùn)算符的返回迭代器的類型如何判斷?
今天小編就為大家分享一篇關(guān)于C++begin和end運(yùn)算符的返回迭代器的類型如何判斷?,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-04-04
C++使用Kruskal和Prim算法實(shí)現(xiàn)最小生成樹
這篇文章主要介紹了C++使用Kruskal和Prim算法實(shí)現(xiàn)最小生成樹,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-01-01

