无码av一区二区三区无码,在线观看老湿视频福利,日韩经典三级片,成 人色 网 站 欧美大片在线观看

歡迎光臨散文網(wǎng) 會員登陸 & 注冊

算法 - 快速排序 詳細(xì)講解!Java實現(xiàn)+復(fù)雜度計算【微軟程序員阿婧的基礎(chǔ)入門

2023-06-09 08:38 作者:_Le_Tian  | 我要投稿

C語言實現(xiàn)QuickSort

// ----- 快速排序 -----


int Partition(SqList &L, int low, int high)

{ // 交換順序表L中子序列L.r[low..high]的記錄,使樞軸記錄到位,并返回其所在位置,此時,在它之前(后)的記錄均不大(?。┯谒?/p>

? ? KeyType pivotkey;

? ? L.r[0] = L.r[low]; ? ? ? // 用子表的第一個記錄作為樞軸記錄

? ? pivotkey = L.r[low].key; // 樞軸記錄關(guān)鍵字

? ? while (low < high)

? ? { // 從表的兩端交替地向中間掃描

? ? ? ? while (low < high && L.r[high].key >= pivotkey)

? ? ? ? {

? ? ? ? ? ? --high;

? ? ? ? }

? ? ? ? L.r[low] = L.r[high]; // 將比樞軸記錄小的記錄移到低端

? ? ? ? while (low < high && L.r[low].key <= pivotkey)

? ? ? ? {

? ? ? ? ? ? ++low;

? ? ? ? }

? ? ? ? L.r[high] = L.r[low]; // 將比樞軸記錄大的記錄移到高端

? ? }

? ? L.r[low] = L.r[0]; // 樞軸記錄到位

? ? return low; ? ? ? ?// 返回樞軸位置

}


void QSort(SqList &L, int low, int high)

{ // 對順序表L中的子序列L.r[low..high]進(jìn)行快速排序

? ? int pivotloc;

? ? if (low < high)

? ? { ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? // 待排序列長度大于1

? ? ? ? pivotloc = Partition(L, low, high); // 將L.r[low..high]一分為二

? ? ? ? QSort(L, low, pivotloc - 1); ? ? ? ?// 對低子表遞歸排序,pivotloc是樞軸位置

? ? ? ? QSort(L, pivotloc + 1, high); ? ? ? // 對高子表遞歸排序

? ? }

}


void QuickSort(SqList &L)

{ // 對順序表L進(jìn)行快速排序

? ? QSort(L, 1, L.length);

}

算法 - 快速排序 詳細(xì)講解!Java實現(xiàn)+復(fù)雜度計算【微軟程序員阿婧的基礎(chǔ)入門的評論 (共 條)

分享到微博請遵守國家法律
改则县| 武清区| 象山县| 新津县| 崇州市| 开江县| 上栗县| 盘锦市| 大邑县| 莆田市| 清流县| 余江县| 台南市| 凭祥市| 白城市| 桦川县| 崇明县| 湟中县| 阜新| 香港| 兴安盟| 长乐市| 常熟市| 迭部县| 理塘县| 彰武县| 民权县| 阳曲县| 蒙自县| 孟州市| 滦平县| 遵义县| 青州市| 太原市| 开封县| 娄烦县| 黑河市| 鹰潭市| 恩施市| 英超| 武夷山市|