亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

詳解計數排序算法及C語言程序中的實現

2020-01-26 14:31:29
字體:
來源:轉載
供稿:網友

關于計數排序算法

當輸入的元素是 n 個 0 到 k 之間的整數時,它的運行時間是 Θ(n + k)。計數排序不是比較排序,排序的速度快于任何比較排序算法。

由于用來計數的數組C的長度取決于待排序數組中數據的范圍(等于待排序數組的最大值與最小值的差加上1),這使得計數排序對于數據范圍很大的數組,需要大量內存。計數排序是用來排序0到100之間的數字的最好的算法,但是它不適合按字母順序排序人名。但是,計數排序可以用在基數排序中的算法來排序數據范圍很大的數組。

算法的步驟如下:

  • 找出待排序的數組中最大和最小的元素
  • 統計數組中每個值為i的元素出現的次數,存入數組C的第i項
  • 對所有的計數累加(從C中的第一個元素開始,每一項和前一項相加)
  • 反向填充目標數組:將每個元素i放在新數組的第C(i)項,每放一個元素就將C(i)減去1

代碼示例:

#include <iostream>#include <cstdio>#include <cstdlib>#include <cmath>#include <cstring>using namespace std;void CountingSort(int *A,int *B,int *Order,int N,int K){  int *C=new int[K+1];  int i;  memset(C,0,sizeof(int)*(K+1));  for (i=1;i<=N;i++) //把A中的每個元素分配    C[A[i]]++;  for (i=2;i<=K;i++) //統計不大于i的元素的個數    C[i]+=C[i-1];  for (i=N;i>=1;i--)  {    B[C[A[i]]]=A[i]; //按照統計的位置,將值輸出到B中,將順序輸出到Order中    Order[C[A[i]]]=i;    C[A[i]]--;  }}int main(){  int *A,*B,*Order,N=15,K=10,i;  A=new int[N+1];  B=new int[N+1];  Order=new int[N+1];  for (i=1;i<=N;i++)    A[i]=rand()%K+1; //生成1..K的隨機數  printf("Before CS:/n");  for (i=1;i<=N;i++)    printf("%d ",A[i]);  CountingSort(A,B,Order,N,K);  printf("/nAfter CS:/n");  for (i=1;i<=N;i++)    printf("%d ",B[i]);  printf("/nOrder:/n");  for (i=1;i<=N;i++)    printf("%d ",Order[i]);  return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美区在线播放| 亚洲一区二区三区乱码aⅴ| 亚洲天堂av网| 91精品国产91久久| 欧美激情xxxx| 亚州欧美日韩中文视频| 亚洲男人的天堂在线播放| 青草青草久热精品视频在线网站| 久久影院资源网| 亚洲精品视频在线观看视频| 日韩成人激情影院| 中文字幕9999| 一区二区欧美亚洲| 91在线视频精品| 日韩av综合中文字幕| 国产精品久久久亚洲| 91国在线精品国内播放| 日本精品一区二区三区在线| 91在线色戒在线| 日韩大片免费观看视频播放| 91亚洲精品在线观看| 欧美视频中文在线看| 欧美激情视频免费观看| 国产精品久久国产精品99gif| 亚洲精品国产综合久久| 亚洲xxxxx性| 亚洲aⅴ日韩av电影在线观看| 欧美综合激情网| 国产精品一久久香蕉国产线看观看| 国产精品jvid在线观看蜜臀| 韩国视频理论视频久久| 久久精品国产欧美激情| 色999日韩欧美国产| 欧美极品美女视频网站在线观看免费| 欧美在线国产精品| 日本高清+成人网在线观看| 在线观看日韩专区| 欧美日在线观看| 国外成人在线直播| 欧美人在线观看| 精品亚洲一区二区三区四区五区| 亚洲精品美女久久久| 欧美一区二粉嫩精品国产一线天| 中文字幕亚洲欧美日韩2019| 精品女同一区二区三区在线播放| 欧美极品少妇全裸体| 国产精品视频地址| 中文字幕在线观看日韩| 亚洲а∨天堂久久精品喷水| 97人人模人人爽人人喊中文字| 国产91精品黑色丝袜高跟鞋| 久久精品国产v日韩v亚洲| 欧美精品久久一区二区| 国产精品a久久久久久| 亚洲最大av在线| 久久香蕉国产线看观看网| 欧美在线视频观看免费网站| 色多多国产成人永久免费网站| 久久精品中文字幕| 久久99热精品这里久久精品| 欧美国产欧美亚洲国产日韩mv天天看完整| 中日韩美女免费视频网址在线观看| 欧美一区二区影院| 国产精品偷伦视频免费观看国产| 狠狠综合久久av一区二区小说| 欧美成人免费播放| 亚洲精品美女久久久| 亚洲国产99精品国自产| 久久久久久久久爱| 91精品国产91久久久久久最新| 欧美日韩视频在线| 亚洲第一精品福利| 97视频网站入口| 日本久久久久久久| 国产综合在线视频| 日韩欧美在线视频免费观看| 91精品国产91久久久久久不卡| 正在播放亚洲1区| 日本国产精品视频| 精品一区二区三区四区在线| 国模精品视频一区二区| 亚洲精品乱码久久久久久按摩观| 亚洲人成亚洲人成在线观看| 日韩高清av在线| 青青久久av北条麻妃海外网| 日韩大片在线观看视频| 日韩网站免费观看高清| 久久久久国产一区二区三区| 欧美美女18p| 欧美另类第一页| 日韩精品福利在线| 国产精品丝袜一区二区三区| 久久综合亚洲社区| 欧美成人精品一区| 96sao精品视频在线观看| 久久精品一本久久99精品| 欧美大全免费观看电视剧大泉洋| 91精品国产高清自在线| 日韩精品高清在线观看| 美女国内精品自产拍在线播放| 亚洲伊人久久大香线蕉av| 久久天天躁狠狠躁老女人| 亚洲护士老师的毛茸茸最新章节| 欧美精品久久久久久久免费观看| 亚洲欧美日韩在线一区| 97精品在线视频| 亚洲欧美制服丝袜| 亚洲国产精品久久| 日韩美女视频中文字幕| 欧美成人手机在线| 国产精品丝袜久久久久久不卡| 在线观看日韩视频| 一区二区欧美激情| 91精品国产网站| 亚洲摸下面视频| 欧美另类极品videosbestfree| 久久久欧美精品| 精品久久久久久国产91| 亚洲精品xxxx| 欧美日韩另类视频| 国产精品久久久久久av福利软件| 国内偷自视频区视频综合| 亚洲国产一区二区三区在线观看| 成人淫片在线看| 在线a欧美视频| 亚洲人成欧美中文字幕| 欧美裸体男粗大视频在线观看| 国模精品视频一区二区| 久久久久久美女| 红桃av永久久久| 国产精品久久久久久久久久新婚| 国产精品久久久久久久一区探花| 久久久精品视频成人| 狠狠色狠狠色综合日日五| 日韩在线精品一区| 欧美日韩亚洲国产一区| 国产成人精品电影| 欧美诱惑福利视频| 91高清视频免费观看| 日韩不卡在线观看| 久久精品一本久久99精品| 国产精品极品美女粉嫩高清在线| 欧美久久久精品| 久久91亚洲精品中文字幕| 中文字幕在线观看亚洲| 国产小视频91| 欧美日韩激情小视频| 久久久最新网址| 精品国产鲁一鲁一区二区张丽| 亚洲国产精品va在线看黑人动漫| 欧美日韩亚洲精品一区二区三区| 麻豆一区二区在线观看| 中文字幕精品在线| 日韩av免费在线播放| 清纯唯美日韩制服另类| 这里只有精品视频在线| 日韩精品在线观| 日韩电影在线观看免费| 亚洲2020天天堂在线观看| 日韩亚洲欧美中文在线| 精品网站999www| 欧美日韩黄色大片| 欧美视频精品一区| 亚洲国产精品人人爽夜夜爽|