计数排序

2021-01-20 20:14

阅读:712

计数排序

排序思想: 对于数组 a[ ] 排序 ,先用数组c[ a[ i ] ] 记录其中的值出现的次数,然后计算前缀和;得出的值的意义就是 对于c[ a[i] ] 的值就是 对于所有的 a[ i ] 最后一个 a[ i ] 在数组中有序的排名,所以借助 ans[ ] 数组记录下标c[a[i] ] 的值为 a[i] ,- - c[ a [ i ] ] 就是 对于所有a[i] ,a[ i ] 的倒数第二个位置。

 1/**计数排序 1~10以内的数*/
2#include
3#include
4#include
5void printArr(int a[],int n)
6
{
7    for(int i=0;i 8        printf("%d%c",a[i],i==n-1?‘\n‘:‘ ‘);
9}
10void countSort(int a[],int n)
11
{
12    int c[12];
13    for(int i=0;i11;i++)
14        c[i]=0;/**清空*/
15
16    for(int i=0;i17        c[a[i]]++;/**计数*/
18
19    for(int i=1;i20        c[i]+=c[i-1];/**前缀和*/
21
22    /**
23    有了前缀和后,数字最后一个a[j]的排名为c[a[j]]
24    所以访问每个数字时,只是把a[j]放到对应的名次上
25    因为可能有多个a[j],所以名次可以从最后一个向前分配
26    */

27    int ans[12];
28    for(int j=n-1;j>=0;j--)
29    {
30        ans[--c[a[j]]]=a[j];
31    }
32    printf("排序后:\n");
33    printArr(ans,10);
34}
35int main()
36
{
37    int a[12];
38    int n=10;
39    /*srand函数设定rand函数所用随机数演算法的种子值*/
40    //srand(time(NULL));
41    /*time(t) t==NULL 返回当前时间,若非空:返回当前时间的同时,将返回值赋予t 指向的内存空间*/
42    for(int i=0;i43        a[i]=rand()%7+1;
44    printArr(a,10);
45    countSort(a,10);
46    return 0;
47}


评论


亲,登录后才可以留言!