从计数排序说起

计数排序是一种非基于元素比较的排序算法,而是将待排序数组元素转化为计数数组的索引值,从而间接使待排序数组具有顺序性。

计数排序的实现一般有两种形式:基于辅助数组和基于桶排序。

基于辅助数组

整个过程包含三个数组:待排序数组A、计数数组B和输出数组C。

简单来说,就是通过统计待排序数组A中元素不同值的分布直方图,生成计数数组B,然后计算计数数组B的前缀和(此步操作可以看成计算待排序数组A中每个元素的位置信息),最后通过逆序循环将元素对应赋值到输出数组C中,输出数组C即是最终排序结果。

基于桶排序

其实就是用桶排序来维护稳定性,因为在每个桶中的元素是以队列结构排序的,可以维护元素的顺序。

主要步骤:

  1. 按元素的最大健值与最小健值之差来创建指定数量的桶,并在每个桶中创建一个队列。
  2. 按顺序遍历待排序数组,将它们放到对应桶的队列中。
  3. 按桶编号顺序进行遍历,将每个桶中队列按顺序输出回原数组中。

计数排序的不足

可以看到辅助数组的长度和桶的数量由最大值和最小值决定,假如两者之差很大,而待排序数组又很小,那么就会导致辅助数组或桶大量浪费。

基数排序

基数排序改善了计数排序,简单来说,基数排序算法就是将整数或字符串切分成不同的数字或字符,然后按对应位置的数或字符分别进行比较,这样就能将辅助数组或桶的数量降低到一个较小的值,经过多轮排序后得到最终的排序结果。

比如下面对于十进制的数值比较,只需要10个桶即可,但要保证每个桶能放得进所有元素。

第一阶段:针对个位数将元素放到对应的桶中。

第二阶段:针对十位数将元素放到对应的桶中。

第三阶段:针对百位数将元素放到对应的桶中。

最终按照桶顺序输出得到排序结果。

桶排序

桶排序是改善计数排序的方法之一,其基本思想是将待排序数组分配到若干个桶内,然后每个桶内再各自进行排序,桶内的排序可以使用不同的算法,比如插入排序或快速排序,属于分治法。每个桶执行完排序后,最后依次将每个桶内的有序序列拿出来,即得到完整的排序结果。

待排序数组的最大元素与最小元素分别为19和1,那么总的范围区间可定义为[0,19],假设用4个桶,则桶的区间分别为[0,4][5,9][10,14][15,19]。可以看到桶的数量可以控制在很小的范围内,而且桶的容量大小可以动态扩充。

按照值将元素放到对应桶内。

按照桶顺序将元素依次输出得到排序结果。

总结

  • 基数排序和桶排序可以看成是计数排序的泛化版本,使用了某些措施优化排序过程。
  • 在桶排序中当桶的个数取最大值(max-min+1)的时候,就变成了计数排序,所以计数排序时桶排序的一种特例。
  • 基数排序可以看做是多轮桶排序,基数排序以有效位的角度,每个有效位都进行一轮桶排序。
  • 当用最大值作为基数时,基数排序就退化成了计数排序。

-------------推荐阅读------------

我的开源项目汇总(机器&深度学习、NLP、网络IO、AIML、mysql协议、chatbot)

为什么写《Tomcat内核设计剖析》

2018汇总数据结构算法篇

2018汇总机器学习篇

2018汇总Java深度篇

2018汇总自然语言处理篇

2018汇总深度学习篇

2018汇总JDK源码篇

2018汇总Java并发核心篇

2018汇总读书篇


跟我交流,向我提问:

欢迎关注:

计数排序vs基数排序vs桶排序相关推荐

  1. 计数排序,基数排序,桶排序

    转 http://blog.163.com/yuyang_tech/blog/static/216050083201382055821953/ 与合并排序,堆排序,快速排序等基于比较的排序算法不同,计 ...

  2. 排序算法之计数排序、基数排序和桶排序

    转自:http://www.cnblogs.com/ttltry-air/archive/2012/08/04/2623302.html 计数排序,基数排序,桶排序等非比较排序算法,平均时间复杂度都是 ...

  3. 【算法学习】线性时间排序-计数排序、基数排序和桶排序详解与编程实现

    计数排序 计数排序假设n个输入元素中的每一个都是介于0到k之间的整数.此处k为某个整数(输入数据在一个小范围内). 算法思想 计数排序的基本思想是对每一个输入元素x,确定出小于x的元素的个数.然后再将 ...

  4. 归并排序,快速排序,冒泡排序,选择排序,基数排序,桶排序,堆排序(c++实现)

    一.归并排序 #include<iostream> using namespace std; void Merge(int arr[],int low,int mid,int high); ...

  5. 排序算法理解总结篇——冒泡排序、选择排序、插入排序、希尔排序、归并排序、堆排序、计数排序、基数排序、桶排序

  6. 基数排序(桶排序)思路分析及代码实现

    基数排序(桶排序)介绍: 基数排序(RadixSort)属于"分配式排序"(DistributionSort),又称"桶子法"(Bucket Sort)顾名思义 ...

  7. 【排序算法】图解桶排序

    目录 前言 桶排序思想 桶排序算法分析 时间复杂度分析 桶排序适用情况 实现一个桶排序 结语 前言 在数据结构与算法的排序中,我们很多人可能更多的熟悉冒泡排序.快速排序.归并排序.可能对堆排序.桶排序 ...

  8. js排序算法详解-桶排序

    全栈工程师开发手册 (作者:栾鹏) js系列教程5-数据结构和算法全解 js排序算法详解-桶排序 一看到这个名字就会觉得奇特,几个意思,我排序还要再准备几个桶不成?还真别说,想用桶排序还得真准备几个桶 ...

  9. c语言排序(快速排序,冒泡排序,选择排序,插入排序,桶排序)

    快速排序,冒泡排序,选择排序,插入排序,桶排序 文章目录 什么是排序 快速排序 实现流程 代码 改进版快速排序代码 注意点 冒泡排序 实现流程 实现代码 选择排序 实现代码 插入排序 实现代码 桶排序 ...

最新文章

  1. 子网,变长子网及超网(CIDR)
  2. LeetCode177 第N高的薪水
  3. 四则运算关于加括号的思路
  4. javafx按钮设计风格_Java,JavaFX的流畅设计风格按钮,切换按钮和工具提示
  5. c语言如何实现玫瑰花
  6. 爱奇艺程序员落户北京后离职被判赔 10 万,网友:太值了简直白送
  7. Spring Boot Serverless 实战系列“架构篇”首发 | 光速入门函数计算
  8. 有哪些神预言的科幻电影
  9. 访问修饰符 public private protected default
  10. linux下目录与文件的权限及特殊权限
  11. Python基础之完数输出
  12. Matlab半方差函数/变异函数
  13. html 半个字符,半角字符什么意思
  14. About MyBatis——有关Mybatis,自问自答系列
  15. 打开cmd的方式与常用的dos命令
  16. 程序人生:黑帽seo新手入门基础教程
  17. Postman学习_Sinno_Song_新浪博客
  18. 力天创见客流分析功能需求
  19. linux_FIFO命名管道-mkfifo函数-进程通信
  20. 逆袭!Xbox One销量超PS4成英国游戏主机销售冠军

热门文章

  1. Python 常用函数 - Python入门教程
  2. 初识C++之运算符重载
  3. python制作加密工具_Python制作钉钉加密/解密工具
  4. php phpexcel用法,PHPExcel用法总结
  5. mysql workbench 1064_MySQL Workbench:查询错误(1064):第1行“ VISIBLE”附近的语?mysql-问答-阿里云开发者社区-阿里云...
  6. linux下使用odbc连接mysql_Linux环境下通过ODBC访问MSSql Server
  7. 权限管理系统_在Gitee狂揽11K Star!这个SpringCloud的权限管理系统你必须知道
  8. 天融信防火墙重置配置_天融信防火墙配置手册
  9. mysql官网 ab_MySQLAB同步
  10. 《软件项目管理(第二版)》期末考试试题总结/复习资料