C++快速排序算法簡明理解
一、問題描述
[問題] 應(yīng)用快速排序方法對(duì)一個(gè)記錄序列進(jìn)行升序排列??焖倥判?quick sort)的分治策略如下。
(1)劃分:選定一個(gè)記錄作為軸值,以軸值為基準(zhǔn)將整個(gè)序列劃分為兩個(gè)子序列r(1)… r(i-1))和r(i+1)…r(n),軸值的位置i在劃分的過程中確定,并且前一個(gè)子序列中的記錄均小于或等于軸值,后一個(gè)子序列中的記錄均大于或等于軸值;
(2)求解子問題:分別對(duì)劃分后的每一個(gè)子序列造歸處理;
(3)合并:由于子序列排序是就地進(jìn)行的,所以合并不需要任何操作。
二、想法
[想法] 首先對(duì)待 排序記錄序列進(jìn)行劃分,劃分的軸值應(yīng)該遵循平衡子問題的原則,使劃分后的兩個(gè)子序列的長度盡量相等,這是決定快速排序算法時(shí)間性能的關(guān)鍵。軸值的選擇有很多方法,例如,可以隨機(jī)選出一個(gè)記錄作為軸值,從而期望劃分是較平衡的。
第一次劃分過程:

后續(xù)排序結(jié)果:

三、算法實(shí)現(xiàn)
int Partition(int r[],int start,int end) {
int i=start,j=end;
while(i<j) {
while (i<j&&r[i]<=r[j]) //對(duì)右側(cè)掃描,即r[i] 與右側(cè)的r[j...i+1]比較,升序排序,如果有小于r[i]的值,即右小于左則跳出循環(huán),還有i>=j也跳出循環(huán),即比較完,沒有比它小的,必須兩個(gè)條件同時(shí)滿足。
j--;
if(i<j) { //在i<j的情況下滿足r[j]<r[i]
r[i]=r[i]^r[j]; //交換值
r[j]=r[i]^r[j]; //注意:如果位置一樣不可以使用異或交換值,即r[1]不能異或r[1];
r[i]=r[i]^r[j]; //也可以定義中間值,進(jìn)行交換
i++;
}
}
while (i<j&&r[i]<=r[j])//對(duì)左側(cè)掃描,即r[j] 與左側(cè)的r[i...j-1]比較,升序排序,如果有大于r[j]的值,即左側(cè)值大于右側(cè)值則跳出循環(huán),還有i>=j也跳出循環(huán),即比較完,沒有比它大的,必須兩個(gè)條件同時(shí)滿足。
i++;
if(i<j) { //在i<j的情況下滿足r[i]>r[j]
r[i]=r[i]^r[j];
r[j]=r[i]^r[j];
r[i]=r[i]^r[j];
j--;
}
return i; //返回軸值
}
void Quicksort(int r[],int start ,int end) { //快速排序
int pivot; //記錄軸值
if(start<end) { //界限值
pivot=Partition(r,start,end); //排序并獲得軸值
Quicksort(r,start,pivot-1); //對(duì)軸值左側(cè)遞歸
Quicksort(r,pivot+1,end); //對(duì)軸值右側(cè)遞歸
}
}
總結(jié)
快速排序是眾多排序方法中,較為重要的一種,它在排序算法中具有排序速度快,而且是就地排序等優(yōu)點(diǎn),使得在許多編程語言的內(nèi)部元素排序?qū)崿F(xiàn)中采用的就是快速排序,很多面試題中也經(jīng)常遇到。
到此這篇關(guān)于C++快速排序算法簡明理解的文章就介紹到這了,更多相關(guān)C++快速排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++使用GDAL庫實(shí)現(xiàn)Tiff文件的讀取
這篇文章主要為大家詳細(xì)介紹了C++使用GDAL庫實(shí)現(xiàn)Tiff文件的讀取的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-03-03
C++?中如何結(jié)束?while?(cin>>str)?的輸入
這篇文章主要介紹了C++?中如何結(jié)束?while?(cin>>str)?的輸入,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
C語言經(jīng)典算法例題求100-999之間的“水仙花數(shù)”
本文的主要內(nèi)容,設(shè)計(jì)一個(gè)程序,找出100-999之間的“水仙花數(shù)”,需要的朋友可以參考下2015-07-07
如何使用visual studio2019創(chuàng)建簡單的MFC窗口(使用C++)
這篇文章主要介紹了如何使用visual studio2019創(chuàng)建簡單的MFC窗口(使用C++),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03

