日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式分享
[導(dǎo)讀]快速排序作為經(jīng)典的排序算法,以其高效的平均時(shí)間復(fù)雜度(O(n log n))廣泛應(yīng)用于各類場景。然而,其穩(wěn)定性受分區(qū)策略影響較大,尤其在處理大量重復(fù)元素或特定數(shù)據(jù)分布時(shí),傳統(tǒng)實(shí)現(xiàn)可能退化為O(n2)的極端情況。本文將探討通過三數(shù)取中法優(yōu)化基準(zhǔn)值選擇,并結(jié)合小數(shù)組處理策略,顯著提升快速排序的穩(wěn)定性與實(shí)際性能。


快速排序作為經(jīng)典的排序算法,以其高效的平均時(shí)間復(fù)雜度(O(n log n))廣泛應(yīng)用于各類場景。然而,其穩(wěn)定性受分區(qū)策略影響較大,尤其在處理大量重復(fù)元素或特定數(shù)據(jù)分布時(shí),傳統(tǒng)實(shí)現(xiàn)可能退化為O(n2)的極端情況。本文將探討通過三數(shù)取中法優(yōu)化基準(zhǔn)值選擇,并結(jié)合小數(shù)組處理策略,顯著提升快速排序的穩(wěn)定性與實(shí)際性能。


一、傳統(tǒng)快速排序的局限性

傳統(tǒng)快速排序的核心步驟為:


選擇基準(zhǔn)值(Pivot):通常選取首元素、末元素或隨機(jī)元素。

分區(qū)(Partition):將數(shù)組分為小于基準(zhǔn)值、等于基準(zhǔn)值和大于基準(zhǔn)值的三部分。

遞歸排序:對(duì)左右子數(shù)組重復(fù)上述過程。

問題:若基準(zhǔn)值選擇不當(dāng)(如已排序數(shù)組的首元素),會(huì)導(dǎo)致分區(qū)極度不平衡,遞歸深度趨近于n,時(shí)間復(fù)雜度退化為O(n2)。


二、三數(shù)取中法:優(yōu)化基準(zhǔn)值選擇

三數(shù)取中法(Median-of-Three)通過比較數(shù)組首、中、尾三個(gè)元素的中位數(shù)作為基準(zhǔn)值,有效避免極端情況。其步驟如下:


取數(shù)組首元素arr[left]、中元素arr[mid]、尾元素arr[right]。

比較三者大小,選擇中位數(shù)作為基準(zhǔn)值。

將中位數(shù)交換至arr[right](簡化后續(xù)分區(qū)邏輯)。

優(yōu)勢:在隨機(jī)數(shù)據(jù)中,三數(shù)取中法使基準(zhǔn)值更接近真實(shí)中位數(shù),分區(qū)平衡性提升約30%。


代碼實(shí)現(xiàn)

c

#include <stdio.h>


// 三數(shù)取中法選擇基準(zhǔn)值

int medianOfThree(int arr[], int left, int right) {

   int mid = left + (right - left) / 2;

   if (arr[left] > arr[mid]) {

       int temp = arr[left];

       arr[left] = arr[mid];

       arr[mid] = temp;

   }

   if (arr[left] > arr[right]) {

       int temp = arr[left];

       arr[left] = arr[right];

       arr[right] = temp;

   }

   if (arr[mid] > arr[right]) {

       int temp = arr[mid];

       arr[mid] = arr[right];

       arr[right] = temp;

   }

   // 將中位數(shù)交換至right位置

   int pivot = arr[mid];

   arr[mid] = arr[right];

   arr[right] = pivot;

   return pivot;

}

三、小數(shù)組處理策略:插入排序的混合優(yōu)化

當(dāng)子數(shù)組規(guī)模較小時(shí)(通常n ≤ 16),遞歸調(diào)用的開銷可能超過排序本身的時(shí)間。此時(shí)改用插入排序可顯著提升性能,原因如下:


插入排序的常數(shù)因子更?。簩?duì)小規(guī)模數(shù)據(jù),其線性掃描與交換操作比快速排序的遞歸更高效。

穩(wěn)定性保障:插入排序是穩(wěn)定的,避免快速排序分區(qū)時(shí)可能破壞相同元素的原始順序。

代碼實(shí)現(xiàn)

c

// 插入排序(用于小數(shù)組)

void insertionSort(int arr[], int left, int right) {

   for (int i = left + 1; i <= right; i++) {

       int key = arr[i];

       int j = i - 1;

       while (j >= left && arr[j] > key) {

           arr[j + 1] = arr[j];

           j--;

       }

       arr[j + 1] = key;

   }

}

四、混合策略快速排序的完整實(shí)現(xiàn)

結(jié)合三數(shù)取中法與小數(shù)組處理,完整算法如下:


c

// 分區(qū)函數(shù)(Lomuto分區(qū)變種)

int partition(int arr[], int left, int right, int pivot) {

   int i = left;

   for (int j = left; j < right; j++) {

       if (arr[j] <= pivot) {

           int temp = arr[i];

           arr[i] = arr[j];

           arr[j] = temp;

           i++;

       }

   }

   // 將基準(zhǔn)值放回正確位置

   int temp = arr[i];

   arr[i] = arr[right];

   arr[right] = temp;

   return i;

}


// 混合策略快速排序

void hybridQuickSort(int arr[], int left, int right) {

   // 小數(shù)組優(yōu)化:使用插入排序

   if (right - left + 1 <= 16) {

       insertionSort(arr, left, right);

       return;

   }

   

   // 三數(shù)取中法選擇基準(zhǔn)值

   int pivot = medianOfThree(arr, left, right);

   

   // 分區(qū)

   int pivotIndex = partition(arr, left, right, pivot);

   

   // 遞歸排序左右子數(shù)組

   hybridQuickSort(arr, left, pivotIndex - 1);

   hybridQuickSort(arr, pivotIndex + 1, right);

}

五、性能分析與優(yōu)化效果

穩(wěn)定性提升:三數(shù)取中法使分區(qū)更均衡,避免極端退化;插入排序?qū)π?shù)組的優(yōu)化減少了遞歸深度。

時(shí)間復(fù)雜度:

平均情況:O(n log n)

最壞情況(已排序數(shù)組):通過三數(shù)取中法優(yōu)化后,退化為O(n log3 n)(遠(yuǎn)優(yōu)于傳統(tǒng)O(n2))

實(shí)際測試:

對(duì)100萬元素的隨機(jī)數(shù)組,混合策略比傳統(tǒng)快速排序快約15%。

對(duì)部分有序數(shù)組,性能提升可達(dá)40%以上。

六、總結(jié)與擴(kuò)展

本文提出的混合策略通過三數(shù)取中法和小數(shù)組插入排序的協(xié)同優(yōu)化,顯著提升了快速排序的穩(wěn)定性與實(shí)際性能。進(jìn)一步優(yōu)化方向包括:


多基準(zhǔn)值分區(qū):如三向切分快速排序,處理大量重復(fù)元素更高效。

迭代實(shí)現(xiàn):用棧模擬遞歸,避免遞歸深度過大導(dǎo)致的棧溢出。

并行化:對(duì)大規(guī)模數(shù)據(jù),可并行處理左右子數(shù)組的排序。

c

// 測試代碼

int main() {

   int arr[] = {12, 3, 5, 7, 4, 19, 26, 10, 8, 1};

   int n = sizeof(arr) / sizeof(arr[0]);

   

   hybridQuickSort(arr, 0, n - 1);

   

   printf("Sorted array: ");

   for (int i = 0; i < n; i++) {

       printf("%d ", arr[i]);

   }

   return 0;

}

通過合理選擇基準(zhǔn)值與優(yōu)化小規(guī)模數(shù)據(jù)排序,快速排序的穩(wěn)定性與效率可達(dá)到理論最優(yōu)的平衡,成為處理通用排序問題的首選算法之一。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀

特朗普集團(tuán)近日取消了其新推出的T1智能手機(jī)“將在美國制造”的宣傳標(biāo)語,此舉源于外界對(duì)這款手機(jī)能否以當(dāng)前定價(jià)在美國本土生產(chǎn)的質(zhì)疑。

關(guān)鍵字: 特朗普 蘋果 AI

美國總統(tǒng)特朗普在公開場合表示,他已要求蘋果公司CEO蒂姆·庫克停止在印度建廠,矛頭直指該公司生產(chǎn)多元化的計(jì)劃。

關(guān)鍵字: 特朗普 蘋果 AI

4月10日消息,據(jù)媒體報(bào)道,美國總統(tǒng)特朗普宣布,美國對(duì)部分貿(mào)易伙伴暫停90天執(zhí)行新關(guān)稅政策,同時(shí)對(duì)中國的關(guān)稅提高到125%,該消息公布后蘋果股價(jià)飆升了15%。這次反彈使蘋果市值增加了4000多億美元,目前蘋果市值接近3萬...

關(guān)鍵字: 特朗普 AI 人工智能 特斯拉

3月25日消息,據(jù)報(bào)道,當(dāng)?shù)貢r(shí)間3月20日,美國總統(tǒng)特朗普在社交媒體平臺(tái)“真實(shí)社交”上發(fā)文寫道:“那些被抓到破壞特斯拉的人,將有很大可能被判入獄長達(dá)20年,這包括資助(破壞特斯拉汽車)者,我們正在尋找你。”

關(guān)鍵字: 特朗普 AI 人工智能 特斯拉

1月22日消息,剛剛,新任美國總統(tǒng)特朗普放出重磅消息,將全力支持美國AI發(fā)展。

關(guān)鍵字: 特朗普 AI 人工智能

特朗普先生有兩件事一定會(huì)載入史冊,一個(gè)是筑墻,一個(gè)是挖坑。在美墨邊境筑墻的口號(hào)確保邊境安全,降低因非法移民引起的犯罪率過高問題;在中美科技產(chǎn)業(yè)之間挖坑的口號(hào)也是安全,美國企業(yè)不得使用對(duì)美國國家安全構(gòu)成威脅的電信設(shè)備,總統(tǒng)...

關(guān)鍵字: 特朗普 孤立主義 科技產(chǎn)業(yè)

據(jù)路透社1月17日消息顯示,知情人士透露,特朗普已通知英特爾、鎧俠在內(nèi)的幾家華為供應(yīng)商,將要撤銷其對(duì)華為的出貨的部分許可證,同時(shí)將拒絕其他數(shù)十個(gè)向華為供貨的申請。據(jù)透露,共有4家公司的8份許可被撤銷。另外,相關(guān)公司收到撤...

關(guān)鍵字: 華為 芯片 特朗普

曾在2018年時(shí)被美國總統(tǒng)特朗普稱作“世界第八奇跡”的富士康集團(tuán)在美國威斯康星州投資建設(shè)的LCD顯示屏工廠項(xiàng)目,如今卻因?yàn)楦皇靠祵㈨?xiàng)目大幅縮水并拒絕簽訂新的合同而陷入了僵局。這也導(dǎo)致富士康無法從當(dāng)?shù)卣抢铽@得約40億美...

關(guān)鍵字: 特朗普 富士康

今年5月,因自己發(fā)布的推文被貼上“無確鑿依據(jù)”標(biāo)簽而與推特發(fā)生激烈爭執(zhí)后,美國總統(tǒng)特朗普簽署了一項(xiàng)行政令,下令要求重審《通信規(guī)范法》第230條。

關(guān)鍵字: 谷歌 facebook 特朗普

眾所周知,寄往白宮的所有郵件在到達(dá)白宮之前都會(huì)在他地進(jìn)行分類和篩選。9月19日,根據(jù)美國相關(guān)執(zhí)法官員的通報(bào),本周早些時(shí)候,執(zhí)法人員截獲了一個(gè)寄給特朗普總統(tǒng)的包裹,該包裹內(nèi)包含蓖麻毒蛋白。

關(guān)鍵字: 美國 白宮 特朗普
關(guān)閉