计数排序

转自:http://www.cnblogs.com/leavingq/archive/2012/01/08/2316560.html

计数排序是一种运行时间在输入的某种假设情况下可以为Θ(n)的算法,它的过程中没有比较环节。

基本的思路就是假设输入序列中任意的元素x都满足x∈[0, k],且x和k都为整数。然后对每一元素x,都确定出序列中比它小的元素的个数,比如为n,则x排序后的位置就应当从n + 1处开始。实现的时候还需要考虑一些细节,比如序列中有几个元素大小相等,因此还需要对大小相等的元素个数进行计数,这样才能正确分配排序后各个元素的位置。

过程中用到了一个辅助序列C,C的大小为k + 1,从C[0]到C[k],它的索引i代表序列中可能出现的大小为i的数,C[i]表示这个数有多少个。下面是算法导论上的例子:

待排序的序列:A = [2, 5, 3, 0, 2, 3, 0, 3]    计数序列:C = [2, 0, 2, 3, 0, 1]

                                                                   索引:        0   1   2   3   4   5

表示序列中0, 1, 2, 3, 4, 5的个数分别为2, 0, 2, 3, 0, 1。

C序列中此时已经隐含了原序列中各个元素应该存放的位置,比如C[0] = 2,意味着大小为0的元素应当占据位置1, 2,而大小为1的元素应当从3开始,但原序列中没有1,因此向后遍历,大小为2的元素从3开始,个数为2,因此占据位置3, 4,以此类推。C[i]从0到n - 1求和的结果就是原序列中比n小的元素个数,假设为m,因此n应当从m开始,一直到m + c[n] - 1

代码:(2012年7月16日 10:22:13)

 1 /*
 2  *@list:待排序数组,要求list[i]是大于等于0的整数;
 3  *@n:总排序元素个数
 4  */
 5  void countSort(element list[],int n)//计数排序
 6  {
 7      int max=list[0];
 8      for(int i=1; i<n; i++)//计算数组中最大元素
 9      {
10          if(list[i]>max)
11              max=list[i];
12      }
13 
14      element* count;
15 
16      count =(element*)malloc(sizeof(element)*(max+1));//数组下标为[0,...max]
17      
18      if(count==NULL)
19          exit(1);//申请空间失败
20 
21      for(int i=0; i<=max; i++)//初试化计数数组
22      {
23          count[i]=0;
24      }
25 
26      for(int i=0; i<n; i++)//计数
27      {
28          int index=list[i];
29          count[index]++;
30      }
31      
32      int j=0;
33      for(int i=0; i<=max; i++)//根据计算数组排序
34      {
35          while(count[i]&&j<n)
36          {
37              list[j]=i;
38              count[i]--;
39              j++;
40          }
41      }
42 
43      free(count);
44      count=NULL;
45  }

转载于:https://www.cnblogs.com/zjhnl/archive/2012/03/29/2422825.html

# 高校智慧校园解决方案摘要 智慧校园解决方案是针对高校信息化建设的核心工程,旨在通过物联网技术实现数字化校园的智能化升级。该方案通过融合计算机技术、网络通信技术、数据库技术和IC卡识别技术,初步实现了校园一卡通系统,进而通过人脸识别技术实现了更精准的校园安全管理、生活管理、教务管理和资源管理。 方案包括多个管理系统:智慧校园管理平台、一卡通卡务管理系统、一卡通人脸库管理平台、智能人脸识别消费管理系统、疫情防控管理系统、人脸识别无感识别管理系统、会议签到管理系统、人脸识别通道管理系统和图书馆对接管理系统。这些系统共同构成了智慧校园的信息化基础,通过统一数据库和操作平台,实现了数据共享和信息一致性。 智能人脸识别消费管理系统通过人脸识别终端,在无需接触的情况下快速完成消费支付过程,提升了校园服务效率。疫情防控管理系统利用热成像测温技术、视频智能分析等手段,实现了对校园人员体温监测和疫情信息实时上报,提高了校园公共卫生事件的预防和控制能力。 会议签到管理系统和人脸识别通道管理系统均基于人脸识别技术,实现了会议的快速签到和图书馆等场所的高效通行管理。与图书馆对接管理系统实现了一卡通系统与图书馆管理系统的无缝集成,提升了图书借阅的便捷性。 总体而言,该智慧校园解决方案通过集成的信息化管理系统,提升了校园管理的智能化水平,优化了校园生活体验,增强了校园安全,并提高了教学和科研的效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值