最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(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ǔ)入門的評論 (共 條)

分享到微博請遵守國家法律
安庆市| 丰城市| 布拖县| 泾阳县| 青岛市| 葵青区| 龙井市| 萨迦县| 栖霞市| 壶关县| 深圳市| 连州市| 哈尔滨市| 攀枝花市| 台中县| 天峻县| 大石桥市| 江油市| 班戈县| 阳泉市| 杭州市| 内丘县| 扬中市| 台安县| 崇阳县| 靖安县| 甘洛县| 垣曲县| 长顺县| 泾源县| 楚雄市| 庆阳市| 泰和县| 伊川县| 繁峙县| 灵川县| 施秉县| 开平市| 江门市| 开封市| 新营市|