码迷,mamicode.com
首页 > 编程语言 > 详细

计数排序及C语言实现

时间:2014-11-25 23:38:33      阅读:281      评论:0      收藏:0      [点我收藏+]

标签:排序算法   算法导论   c语言   


之前讨论的插入排序、归并排序、堆排序和快速排序都是基于比较的排序算法,对于所有的比较排序算法,其复杂度最优也要O(nlgn)。证明过程请参考算法导论第八章第一节。


今天介绍一种非比较排序,名为计数排序。

基本思想是:对于每一个元素,确定小于该元素的个数,就可以将该元素排在正确的位置。该算法能达到线性时间复杂度,也就是O(n)。


程序中,数组a为输入数组(未排序数组),b为输出数组,c为中间数组。20的意思是假设数组中每个元素均为小于20的非负整数。

bubuko.com,布布扣

计数排序及C语言实现

标签:排序算法   算法导论   c语言   

原文地址:http://blog.csdn.net/bing_bing304/article/details/41492103

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!