在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

C++基礎(chǔ)語(yǔ)法十大排序算法后五個(gè)分享

C語(yǔ)言編程學(xué)習(xí)基地 ? 來源:C語(yǔ)言編程學(xué)習(xí)基地 ? 作者:C語(yǔ)言編程學(xué)習(xí)基地 ? 2021-10-08 15:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本期是C++基礎(chǔ)語(yǔ)法分享的第十六節(jié),今天給大家來梳理一下十大排序算法后五個(gè)!

a9519302-2426-11ec-82a8-dac502259ad0.png

歸并排序

歸并排序:把數(shù)據(jù)分為兩段,從兩段中逐個(gè)選最小的元素移入新數(shù)據(jù)段的末尾。可從上到下或從下到上進(jìn)行。

/***************** 迭代版*****************

///整數(shù)或浮點(diǎn)數(shù)皆可使用,若要使用物件(class)時(shí)必須設(shè)定“小於”(《)的運(yùn)算子功能template《typename T》void merge_sort(T arr[], int len) { T* a = arr;

T* b = new T[len]; for (int seg = 1;

seg 《 len; seg += seg) { for (int start = 0; start 《 len; start += seg + seg) { int low = start, mid = min(start + seg, len), high = min(start + seg + seg, len);

int k = low; int start1 = low, end1 = mid; int start2 = mid, end2 = high; while (start1 《 end1 && start2 《 end2) b[k++] = a[start1] 《 a[start2] ? a[start1++] : a[start2++]; while (start1 《 end1) b[k++] = a[start1++];

while (start2 《 end2) b[k++] = a[start2++]; } T* temp = a;

a = b; b = temp; } if (a != arr) { for (int i = 0; i 《 len; i++) b[i] = a[i]; b = a;

} delete[] b;}

/***************** 遞歸版*****************/template《typename T》void merge_sort_recursive(T arr[], T reg[], int start, int end) { if (start 》= end) return; int len = end - start, mid = (len 》》 1) + start; int start1 = start, end1 = mid;

int start2 = mid + 1, end2 = end; merge_sort_recursive(arr, reg, start1, end1); merge_sort_recursive(arr, reg, start2, end2);

int k = start; while (start1 《= end1 && start2 《= end2) reg[k++] = arr[start1] 《 arr[start2] ? arr[start1++] : arr[start2++];

while (start1 《= end1) reg[k++] = arr[start1++]; while (start2 《= end2) reg[k++] = arr[start2++];

for (k = start; k 《= end; k++) arr[k] = reg[k];}//整數(shù)或浮點(diǎn)數(shù)皆可使用,若要使用物件(class)時(shí)必須設(shè)定“小於”(《)的運(yùn)算子功能template《typename T》 void merge_sort(T arr[], const int len) { T *reg = new T[len]; merge_sort_recursive(arr, reg, 0, len - 1); delete[] reg;}

希爾排序

希爾排序:每一輪按照事先決定的間隔進(jìn)行插入排序,間隔會(huì)依次縮小,最后一次一定要是1。

template《typename T》void shell_sort(T array[], int length) { int h = 1; while (h 《 length / 3) { h = 3 * h + 1; } while (h 》= 1) { for (int i = h; i 《 length; i++) { for (int j = i; j 》= h && array[j] 《 array[j - h]; j -= h) { std::swap(array[j], array[j - h]); } } h = h / 3; }}

計(jì)數(shù)排序

計(jì)數(shù)排序:統(tǒng)計(jì)小于等于該元素值的元素的個(gè)數(shù)i,于是該元素就放在目標(biāo)數(shù)組的索引i位(i≥0)。

計(jì)數(shù)排序基于一個(gè)假設(shè),待排序數(shù)列的所有數(shù)均為整數(shù),且出現(xiàn)在(0,k)的區(qū)間之內(nèi)。

如果 k(待排數(shù)組的最大值) 過大則會(huì)引起較大的空間復(fù)雜度,一般是用來排序 0 到 100 之間的數(shù)字的最好的算法,但是它不適合按字母順序排序人名。

計(jì)數(shù)排序不是比較排序,排序的速度快于任何比較排序算法。

時(shí)間復(fù)雜度為 O(n+k),空間復(fù)雜度為 O(n+k)

算法的步驟如下:

1. 找出待排序的數(shù)組中最大和最小的元素

2. 統(tǒng)計(jì)數(shù)組中每個(gè)值為 i 的元素出現(xiàn)的次數(shù),存入數(shù)組 C 的第 i 項(xiàng)

3. 對(duì)所有的計(jì)數(shù)累加(從 C 中的第一個(gè)元素開始,每一項(xiàng)和前一項(xiàng)相加)

4. 反向填充目標(biāo)數(shù)組:將每個(gè)元素 i 放在新數(shù)組的第 C[i] 項(xiàng),每放一個(gè)元素就將 C[i] 減去 1

#include 《iostream》#include 《vector》#include 《algorithm》

using namespace std;

// 計(jì)數(shù)排序void CountSort(vector《int》& vecRaw, vector《int》& vecObj){ // 確保待排序容器非空 if (vecRaw.size() == 0) return;

// 使用 vecRaw 的最大值 + 1 作為計(jì)數(shù)容器 countVec 的大小 int vecCountLength = (*max_element(begin(vecRaw), end(vecRaw))) + 1; vector《int》 vecCount(vecCountLength, 0);

// 統(tǒng)計(jì)每個(gè)鍵值出現(xiàn)的次數(shù) for (int i = 0; i 《 vecRaw.size(); i++) vecCount[vecRaw[i]]++; // 后面的鍵值出現(xiàn)的位置為前面所有鍵值出現(xiàn)的次數(shù)之和 for (int i = 1; i 《 vecCountLength; i++) vecCount[i] += vecCount[i - 1];

// 將鍵值放到目標(biāo)位置 for (int i = vecRaw.size(); i 》 0; i--) // 此處逆序是為了保持相同鍵值的穩(wěn)定性 vecObj[--vecCount[vecRaw[i - 1]]] = vecRaw[i - 1];}

int main(){ vector《int》 vecRaw = { 0,5,7,9,6,3,4,5,2,8,6,9,2,1 }; vector《int》 vecObj(vecRaw.size(), 0);

CountSort(vecRaw, vecObj);

for (int i = 0; i 《 vecObj.size(); ++i) cout 《《 vecObj[i] 《《 “ ”; cout 《《 endl;

return 0;}

桶排序

桶排序:將值為i的元素放入i號(hào)桶,最后依次把桶里的元素倒出來。

桶排序序思路:

1. 設(shè)置一個(gè)定量的數(shù)組當(dāng)作空桶子。

2. 尋訪序列,并且把項(xiàng)目一個(gè)一個(gè)放到對(duì)應(yīng)的桶子去。

3. 對(duì)每個(gè)不是空的桶子進(jìn)行排序。

4. 從不是空的桶子里把項(xiàng)目再放回原來的序列中。

假設(shè)數(shù)據(jù)分布在[0,100)之間,每個(gè)桶內(nèi)部用鏈表表示,在數(shù)據(jù)入桶的同時(shí)插入排序,然后把各個(gè)桶中的數(shù)據(jù)合并。

const int BUCKET_NUM = 10;

struct ListNode{ explicit ListNode(int i=0):mData(i),mNext(NULL){} ListNode* mNext; int mData;};

ListNode* insert(ListNode* head,int val){ ListNode dummyNode; ListNode *newNode = new ListNode(val); ListNode *pre,*curr; dummyNode.mNext = head; pre = &dummyNode; curr = head; while(NULL!=curr && curr-》mData《=val){ pre = curr; curr = curr-》mNext; } newNode-》mNext = curr; pre-》mNext = newNode; return dummyNode.mNext;}

ListNode* Merge(ListNode *head1,ListNode *head2){ ListNode dummyNode; ListNode *dummy = &dummyNode; while(NULL!=head1 && NULL!=head2){ if(head1-》mData 《= head2-》mData){ dummy-》mNext = head1; head1 = head1-》mNext; }else{ dummy-》mNext = head2; head2 = head2-》mNext; } dummy = dummy-》mNext; } if(NULL!=head1) dummy-》mNext = head1; if(NULL!=head2) dummy-》mNext = head2; return dummyNode.mNext;}

void BucketSort(int n,int arr[]){ vector《ListNode*》 buckets(BUCKET_NUM,(ListNode*)(0)); for(int i=0;i《n;++i){ int index = arr[i]/BUCKET_NUM; ListNode *head = buckets.at(index); buckets.at(index) = insert(head,arr[i]); } ListNode *head = buckets.at(0); for(int i=1;i《BUCKET_NUM;++i){ head = Merge(head,buckets.at(i)); } for(int i=0;i《n;++i){ arr[i] = head-》mData; head = head-》mNext; }}

基數(shù)排序

基數(shù)排序:一種多關(guān)鍵字的排序算法,可用桶排序?qū)崿F(xiàn)。

int maxbit(int data[], int n) //輔助函數(shù),求數(shù)據(jù)的最大位數(shù){ int maxData = data[0]; ///《 最大數(shù) /// 先求出最大數(shù),再求其位數(shù),這樣有原先依次每個(gè)數(shù)判斷其位數(shù),稍微優(yōu)化點(diǎn)。 for (int i = 1; i 《 n; ++i) { if (maxData 《 data[i]) maxData = data[i];

} int d = 1;

int p = 10; while (maxData 》= p) { //p *= 10; // Maybe overflow maxData /= 10; ++d; } return d;/* int d = 1; //保存最大的位數(shù) int p = 10; for(int i = 0; i 《 n; ++i) { while(data[i] 》= p) { p *= 10; ++d;

} } return d;*/}void radixsort(int data[], int n) //基數(shù)排序{ int d = maxbit(data, n);

int *tmp = new int[n]; int *count = new int[10];

//計(jì)數(shù)器 int i, j, k; int radix = 1; for(i = 1; i 《= d; i++) //進(jìn)行d次排序 { for(j = 0; j 《 10; j++) count[j] = 0; //每次分配前清空計(jì)數(shù)器 for(j = 0; j 《 n; j++) { k = (data[j] / radix) % 10; //統(tǒng)計(jì)每個(gè)桶中的記錄數(shù) count[k]++; } for(j = 1; j 《 10; j++) count[j] = count[j - 1] + count[j];

//將tmp中的位置依次分配給每個(gè)桶 for(j = n - 1; j 》= 0; j--) //將所有桶中記錄依次收集到tmp中 { k = (data[j] / radix) % 10; tmp[count[k] - 1] = data[j];

count[k]--; } for(j = 0; j 《 n; j++) //將臨時(shí)數(shù)組的內(nèi)容復(fù)制到data中 data[j] = tmp[j]; radix = radix * 10;

} delete []tmp; delete []count;}

今天的分享就到這里了,大家要好好學(xué)C++喲~

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3686

    瀏覽量

    95036
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2118

    瀏覽量

    74966

原文標(biāo)題:C++基礎(chǔ)語(yǔ)法梳理:算法丨十大排序算法(二)

文章出處:【微信號(hào):cyuyanxuexi,微信公眾號(hào):C語(yǔ)言編程學(xué)習(xí)基地】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    工業(yè)路由器品牌前十大排

    、產(chǎn)品覆蓋廣泛的企業(yè)。本文結(jié)合行業(yè)權(quán)威榜單與市場(chǎng)動(dòng)態(tài),梳理2024-2025年工業(yè)路由器品牌前十大排名(排名不分先后) 一、品牌綜合實(shí)力與產(chǎn)品特點(diǎn) 1. 星創(chuàng)易聯(lián) 星創(chuàng)易聯(lián)憑借高性能處理器與多協(xié)議兼容性穩(wěn)居國(guó)內(nèi)工業(yè)路由器市場(chǎng)前列。其產(chǎn)
    的頭像 發(fā)表于 03-27 16:21 ?541次閱讀

    C++學(xué)到什么程度可以找工作?

    C++學(xué)到什么程度可以找工作?要使用C++找到工作,特別是作為軟件開發(fā)人員或相關(guān)職位,通常需要掌握以下幾個(gè)方面: 1. **語(yǔ)言基礎(chǔ)**:你需要對(duì)C++的核心概念有扎實(shí)的理解,包括但不限于指針、內(nèi)存
    發(fā)表于 03-13 10:19

    rtsmart開啟C++特性支持,工具鏈編譯內(nèi)核不通過怎么解決?

    各位大佬好,本人在rtsmart項(xiàng)目中需要使用C++11特性,在menuconfig那里配置了支持C++特性,使用7.3.0版本的arm-linux-musleabi編譯器編譯內(nèi)核時(shí)出現(xiàn) 錯(cuò)誤
    發(fā)表于 03-10 08:06

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)的C++公共基礎(chǔ)類庫(kù)案例:ThreadPoll

    1、程序簡(jiǎn)介該程序是基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)的C++公共基礎(chǔ)類庫(kù)的線程池處理:ThreadPoll。本案例完成如下工作:創(chuàng)建1個(gè)線程池,設(shè)置該線程池內(nèi)部有1024個(gè)線程空間。啟動(dòng)5個(gè)
    的頭像 發(fā)表于 02-10 18:09 ?330次閱讀
    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)的<b class='flag-5'>C++</b>公共基礎(chǔ)類庫(kù)案例:ThreadPoll

    Spire.XLS for C++組件說明

    Spire.XLS for C++ 是一款專業(yè)的 C++ Excel 組件,可以用在各種 C++ 框架和應(yīng)用程序中。Spire.XLS for C++ 提供了一
    的頭像 發(fā)表于 01-14 09:40 ?581次閱讀
    Spire.XLS for <b class='flag-5'>C++</b>組件說明

    TimSort:一個(gè)在標(biāo)準(zhǔn)函數(shù)庫(kù)中廣泛使用的排序算法

    排序算法呢? 本文將帶你走進(jìn) TimSort,一個(gè)在標(biāo)準(zhǔn)函數(shù)庫(kù)中廣泛使用的排序算法。 這個(gè)算法
    的頭像 發(fā)表于 01-03 11:42 ?541次閱讀

    AKI跨語(yǔ)言調(diào)用庫(kù)神助攻C/C++代碼遷移至HarmonyOS NEXT

    )開發(fā)框架。它極大地簡(jiǎn)化了JS與C/C++之間的跨語(yǔ)言訪問,為開發(fā)者提供了一種邊界性編程體驗(yàn)友好的解決方案。通過AKI,開發(fā)者可以使用讓代碼更易讀的語(yǔ)法糖,實(shí)現(xiàn)JS與C/
    發(fā)表于 01-02 17:08

    同樣是函數(shù),在CC++中有什么區(qū)別

    同樣是函數(shù),在 CC++ 中有什么區(qū)別? 第一個(gè)返回值。 C語(yǔ)言的函數(shù)可以不寫返回值類型,編譯器會(huì)默認(rèn)為返回 int。 但是 C++
    的頭像 發(fā)表于 11-29 10:25 ?861次閱讀

    C++新手容易犯的十個(gè)編程錯(cuò)誤

    簡(jiǎn)單的總結(jié)一下?C++ 新手容易犯的一些編程錯(cuò)誤,給新人們提供一個(gè)參考。 1 有些關(guān)鍵字在 cpp 文件中多寫了 對(duì)于 C++ 類,一些關(guān)鍵字只要寫在 .h 中就好,cpp 中就不用再加上了,比如
    的頭像 發(fā)表于 11-15 12:42 ?972次閱讀

    C語(yǔ)言和C++中結(jié)構(gòu)體的區(qū)別

    同樣是結(jié)構(gòu)體,看看在C語(yǔ)言和C++中有什么區(qū)別?
    的頭像 發(fā)表于 10-30 15:11 ?714次閱讀

    C7000優(yōu)化C/C++編譯器

    電子發(fā)燒友網(wǎng)站提供《C7000優(yōu)化C/C++編譯器.pdf》資料免費(fèi)下載
    發(fā)表于 10-30 09:45 ?0次下載
    <b class='flag-5'>C</b>7000優(yōu)化<b class='flag-5'>C</b>/<b class='flag-5'>C++</b>編譯器

    時(shí)間復(fù)雜度為 O(n^2) 的排序算法

    , O(n2) 的排序算法可能會(huì)比 O(nlogn) 的排序算法執(zhí)行效率高。不過隨著數(shù)據(jù)規(guī)模增大, O(nlogn) 的排序
    的頭像 發(fā)表于 10-19 16:31 ?1681次閱讀
    時(shí)間復(fù)雜度為 O(n^2) 的<b class='flag-5'>排序</b><b class='flag-5'>算法</b>

    c++編譯鏈接失敗的原因?如何解決?

    /c++項(xiàng)目,將剛才新建的項(xiàng)目轉(zhuǎn)換為c++項(xiàng)目。 完成后點(diǎn)擊編譯,此時(shí)也是正常的。 新建一個(gè)cpp文件,將原項(xiàng)目的main.c中內(nèi)容全部拷貝到新建的cpp文件中保存,然后刪除原main
    發(fā)表于 07-25 08:13

    C++語(yǔ)言基礎(chǔ)知識(shí)

    電子發(fā)燒友網(wǎng)站提供《C++語(yǔ)言基礎(chǔ)知識(shí).pdf》資料免費(fèi)下載
    發(fā)表于 07-19 10:58 ?8次下載

    C++中實(shí)現(xiàn)類似instanceof的方法

    C++有多態(tài)與繼承,但是很多人開始學(xué)習(xí)C++,有時(shí)候會(huì)面臨一個(gè)常見問題,就是如何向下轉(zhuǎn)型,特別是不知道具體類型的時(shí)候,這個(gè)時(shí)候就希望C++ 可以向Java或者Python中有insta
    的頭像 發(fā)表于 07-18 10:16 ?894次閱讀
    <b class='flag-5'>C++</b>中實(shí)現(xiàn)類似instanceof的方法
    主站蜘蛛池模板: 久久精品免看国产 | 天天摸天天操天天爽 | 日本黄页网站 | 亚洲国产欧美在线人成aaa | 欧美亚洲综合另类型色妞 | 欧美最猛黑人xxxx黑人猛交69 | 亚洲狠狠狠一区二区三区 | 国产成人精品日本亚洲直接 | 九色欧美| 91网站在线看 | 性久久久久久久久 | 欧美高清一区 | 亚洲人成电影在线小说网色 | 色在线观看视频 | 丁香婷婷在线视频 | 精品国产一区二区三区国产馆 | 亚洲人色大成年网站在线观看 | 色偷偷尼玛图亚洲综合 | 免费一级毛片在线播放 | 毛片毛片免费看 | 精品国产污污免费网站入口 | 午夜性爽视频男人的天堂在线 | 国产毛片一区二区三区精品 | 五月婷婷色丁香 | 四虎影视免费 | 成年片色大黄全免费网址 | 国产99在线播放 | 日本三级视频在线 | 午夜视频福利在线 | 色综合天天综合网看在线影院 | 国产99久9在线视频 国产99久久九九精品免费 | 午夜刺激爽爽视频免费观看 | 黄色三级网站免费 | 日韩一级精品视频在线观看 | 在线观看不卡一区 | 欧美色a电影精品aaaa | 99久久精品久久久久久婷婷 | 99国产成人精品2021 | 四虎伦理 | 久久99色| 男人日女人视频在线观看 |