溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++中怎樣實現(xiàn)快速排序

發(fā)布時間:2021-08-13 17:24:49 來源:億速云 閱讀:110 作者:Leah 欄目:開發(fā)技術

這期內容當中小編將會給大家?guī)碛嘘PC++中怎樣實現(xiàn)快速排序,文章內容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。


快速排序是對冒泡排序算法的一種改進,快速排序算法通過多次比較和交換來實現(xiàn)排序。

流程如下:

C++中怎樣實現(xiàn)快速排序 

實現(xiàn)

以下有兩種實現(xiàn)方式,說是兩種,其實就是在交換元素時具體細節(jié)上有點不同罷了。

方式一

int Partition(int A[],int low,int high){
	int pivot=A[low];//第一個元素作為基準
	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);
	}
}

該方式,先把基準元素保存起來

如下圖數(shù)組,把49看作基準元素,先移動high指針,當指向27時退出while循環(huán),把27放到low位置

C++中怎樣實現(xiàn)快速排序

C++中怎樣實現(xiàn)快速排序

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

C++中怎樣實現(xiàn)快速排序

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

C++中怎樣實現(xiàn)快速排序

最后得到如下圖的情況:

C++中怎樣實現(xiàn)快速排序

這樣我們就按照“49”,把數(shù)組分為了左右兩部分。

對左右兩部分分別進行上述操作即可。

C++中怎樣實現(xià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);
}

對于第二種方式,看下圖即可很好理解。

高低指針不是輪流替換空余位置,而是同時找到不符合的元素,然后交換二者。

最后,高低指針相遇,再把基準元素與相遇位置上的元素交換即可。

C++中怎樣實現(xiàn)快速排序

C++中怎樣實現(xiàn)快速排序

C++中怎樣實現(xiàn)快速排序

C++中怎樣實現(xiàn)快速排序

上述就是小編為大家分享的C++中怎樣實現(xiàn)快速排序了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

c++
AI