這篇文章運(yùn)用簡單易懂的例子給大家介紹C語言中快速排序法如何使用,代碼非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。
成都創(chuàng)新互聯(lián)公司是一家成都網(wǎng)站建設(shè)、成都網(wǎng)站制作,提供網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),網(wǎng)站制作,建網(wǎng)站,按需求定制開發(fā),網(wǎng)站開發(fā)公司,從2013年開始是互聯(lián)行業(yè)建設(shè)者,服務(wù)者。以提升客戶品牌價(jià)值為核心業(yè)務(wù),全程參與項(xiàng)目的網(wǎng)站策劃設(shè)計(jì)制作,前端開發(fā),后臺(tái)程序制作以及后期項(xiàng)目運(yùn)營并提出專業(yè)建議和思路。快速排序法的排法:首先每次排序的時(shí)候設(shè)置一個(gè)基準(zhǔn)點(diǎn),將小于等于基準(zhǔn)點(diǎn)的數(shù)全部放到基準(zhǔn)點(diǎn)的左邊;然后將大于等于基準(zhǔn)點(diǎn)的數(shù)全部放到基準(zhǔn)點(diǎn)的右邊;最后在每次交換的時(shí)候就不會(huì)像冒泡排序一樣每次只能在相鄰的數(shù)之間進(jìn)行交換,交換的距離就大的多了。
快速排序法的排法:
算法思想:
(1) 我們從待排序的記錄序列中選取一個(gè)記錄(通常第一個(gè))作為基準(zhǔn)元素(稱為key)key=arr[left],然后設(shè)置兩個(gè)變量,left指向數(shù)列的最左部,right指向數(shù)據(jù)的最右部。
(2) key首先與arr[right]進(jìn)行比較,如果arr[right] (3) 如果右邊存在arr[right] (4) 然后再移動(dòng)right重復(fù)上述步驟 (5) 最后得到 {23 58 13 10 57 62} 65 {106 78 95 85},再對(duì)左子數(shù)列與右子數(shù)列進(jìn)行同樣的操作。最終得到一個(gè)有序的數(shù)列。 算法實(shí)現(xiàn): 關(guān)于C語言中快速排序法如何使用就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。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]
當(dāng)前名稱:C語言中快速排序法如何使用-創(chuàng)新互聯(lián)
文章地址:http://weahome.cn/article/icjeg.html