日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

【排序算法】计数排序

發(fā)布時(shí)間:2023/11/30 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【排序算法】计数排序 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

當(dāng)輸入的元素是 n 個(gè) 0 到 k 之間的整數(shù)時(shí),它的運(yùn)行時(shí)間是 Θ(n + k)。計(jì)數(shù)排序不是比較排序,排序的速度快于任何比較排序算法。

由于用來(lái)計(jì)數(shù)的數(shù)組B的長(zhǎng)度取決于待排序數(shù)組中數(shù)據(jù)的范圍(等于待排序數(shù)組的最大值與最小值的差加上1),這使得計(jì)數(shù)排序?qū)τ跀?shù)據(jù)范圍很大的數(shù)組,需要大量?jī)?nèi)存。計(jì)數(shù)排序是用來(lái)排序0到100之間的數(shù)字的最好的算法,但是它不適合按字母順序排序人名。但是,計(jì)數(shù)排序可以用在基數(shù)排序中的算法來(lái)排序數(shù)據(jù)范圍很大的數(shù)組。

測(cè)試代碼

#include <iostream> using namespace std;void print(int a[], int sz) {for (int i = 0; i < sz; i++) cout << a[i] << " ";cout << endl; }void CountingSort(int arr[], int sz) {int i, j, k;int idx = 0;int min, max;min = max = arr[0];for (i = 1; i < sz; i++) {min = (arr[i] < min) ? arr[i] : min;max = (arr[i] > max) ? arr[i] : max;}k = max - min + 1;int *B = new int[k];for(i = 0; i < k; i++)B[i] = 0;for(i = 0; i < sz; i++) B[arr[i] - min]++; //記錄該元素的個(gè)數(shù)for(i = min; i <= max; i++)for(j = 0; j < B[i - min]; j++) arr[idx++] = i;print(arr, sz);delete[] B; }int main() {int a[] = { 5,9,3,9,10,9,2,4,13,10 };const size_t sz = sizeof(a) / sizeof(a[0]);print(a, sz);cout << "----------------------\n";CountingSort(a, sz); }

參考資料

1.??漫畫:什么是計(jì)數(shù)排序??

總結(jié)

以上是生活随笔為你收集整理的【排序算法】计数排序的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。