新聞中心
這篇文章運用簡單易懂的例子給大家介紹C語言中快速排序法如何使用,代碼非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
快速排序法的排法:首先每次排序的時候設置一個基準點,將小于等于基準點的數(shù)全部放到基準點的左邊;然后將大于等于基準點的數(shù)全部放到基準點的右邊;最后在每次交換的時候就不會像冒泡排序一樣每次只能在相鄰的數(shù)之間進行交換,交換的距離就大的多了。
快速排序法的排法:
算法思想:
(1) 我們從待排序的記錄序列中選取一個記錄(通常第一個)作為基準元素(稱為key)key=arr[left],然后設置兩個變量,left指向數(shù)列的最左部,right指向數(shù)據(jù)的最右部。
(2) key首先與arr[right]進行比較,如果arr[right] (3) 如果右邊存在arr[right] (4) 然后再移動right重復上述步驟 (5) 最后得到 {23 58 13 10 57 62} 65 {106 78 95 85},再對左子數(shù)列與右子數(shù)列進行同樣的操作。最終得到一個有序的數(shù)列。 算法實現(xiàn): 關于C語言中快速排序法如何使用就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。public class QuickSort {
public static void quickSort(int [] arr,int left,int right) {
int pivot=0;
if(left
排序前:[65, 58, 95, 10, 57, 62, 13, 106, 78, 23, 85]
排序后:[10, 13, 23, 57, 58, 62, 65, 78, 85, 95, 106]
名稱欄目:C語言中快速排序法如何使用-創(chuàng)新互聯(lián)
URL網(wǎng)址:http://www.dlmjj.cn/article/icjeg.html