计数排序vs基数排序vs桶排序
从计数排序说起
计数排序是一种非基于元素比较的排序算法,而是将待排序数组元素转化为计数数组的索引值,从而间接使待排序数组具有顺序性。
计数排序的实现一般有两种形式:基于辅助数组和基于桶排序。
基于辅助数组
整个过程包含三个数组:待排序数组A、计数数组B和输出数组C。
简单来说,就是通过统计待排序数组A中元素不同值的分布直方图,生成计数数组B,然后计算计数数组B的前缀和(此步操作可以看成计算待排序数组A中每个元素的位置信息),最后通过逆序循环将元素对应赋值到输出数组C中,输出数组C即是最终排序结果。
基于桶排序
其实就是用桶排序来维护稳定性,因为在每个桶中的元素是以队列结构排序的,可以维护元素的顺序。
主要步骤:
- 按元素的最大健值与最小健值之差来创建指定数量的桶,并在每个桶中创建一个队列。
- 按顺序遍历待排序数组,将它们放到对应桶的队列中。
- 按桶编号顺序进行遍历,将每个桶中队列按顺序输出回原数组中。
计数排序的不足
可以看到辅助数组的长度和桶的数量由最大值和最小值决定,假如两者之差很大,而待排序数组又很小,那么就会导致辅助数组或桶大量浪费。
基数排序
基数排序改善了计数排序,简单来说,基数排序算法就是将整数或字符串切分成不同的数字或字符,然后按对应位置的数或字符分别进行比较,这样就能将辅助数组或桶的数量降低到一个较小的值,经过多轮排序后得到最终的排序结果。
比如下面对于十进制的数值比较,只需要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桶排序相关推荐
- 计数排序,基数排序,桶排序
转 http://blog.163.com/yuyang_tech/blog/static/216050083201382055821953/ 与合并排序,堆排序,快速排序等基于比较的排序算法不同,计 ...
- 排序算法之计数排序、基数排序和桶排序
转自:http://www.cnblogs.com/ttltry-air/archive/2012/08/04/2623302.html 计数排序,基数排序,桶排序等非比较排序算法,平均时间复杂度都是 ...
- 【算法学习】线性时间排序-计数排序、基数排序和桶排序详解与编程实现
计数排序 计数排序假设n个输入元素中的每一个都是介于0到k之间的整数.此处k为某个整数(输入数据在一个小范围内). 算法思想 计数排序的基本思想是对每一个输入元素x,确定出小于x的元素的个数.然后再将 ...
- 归并排序,快速排序,冒泡排序,选择排序,基数排序,桶排序,堆排序(c++实现)
一.归并排序 #include<iostream> using namespace std; void Merge(int arr[],int low,int mid,int high); ...
- 排序算法理解总结篇——冒泡排序、选择排序、插入排序、希尔排序、归并排序、堆排序、计数排序、基数排序、桶排序
- 基数排序(桶排序)思路分析及代码实现
基数排序(桶排序)介绍: 基数排序(RadixSort)属于"分配式排序"(DistributionSort),又称"桶子法"(Bucket Sort)顾名思义 ...
- 【排序算法】图解桶排序
目录 前言 桶排序思想 桶排序算法分析 时间复杂度分析 桶排序适用情况 实现一个桶排序 结语 前言 在数据结构与算法的排序中,我们很多人可能更多的熟悉冒泡排序.快速排序.归并排序.可能对堆排序.桶排序 ...
- js排序算法详解-桶排序
全栈工程师开发手册 (作者:栾鹏) js系列教程5-数据结构和算法全解 js排序算法详解-桶排序 一看到这个名字就会觉得奇特,几个意思,我排序还要再准备几个桶不成?还真别说,想用桶排序还得真准备几个桶 ...
- c语言排序(快速排序,冒泡排序,选择排序,插入排序,桶排序)
快速排序,冒泡排序,选择排序,插入排序,桶排序 文章目录 什么是排序 快速排序 实现流程 代码 改进版快速排序代码 注意点 冒泡排序 实现流程 实现代码 选择排序 实现代码 插入排序 实现代码 桶排序 ...
最新文章
- 子网,变长子网及超网(CIDR)
- LeetCode177 第N高的薪水
- 四则运算关于加括号的思路
- javafx按钮设计风格_Java,JavaFX的流畅设计风格按钮,切换按钮和工具提示
- c语言如何实现玫瑰花
- 爱奇艺程序员落户北京后离职被判赔 10 万,网友:太值了简直白送
- Spring Boot Serverless 实战系列“架构篇”首发 | 光速入门函数计算
- 有哪些神预言的科幻电影
- 访问修饰符 public private protected default
- linux下目录与文件的权限及特殊权限
- Python基础之完数输出
- Matlab半方差函数/变异函数
- html 半个字符,半角字符什么意思
- About MyBatis——有关Mybatis,自问自答系列
- 打开cmd的方式与常用的dos命令
- 程序人生:黑帽seo新手入门基础教程
- Postman学习_Sinno_Song_新浪博客
- 力天创见客流分析功能需求
- linux_FIFO命名管道-mkfifo函数-进程通信
- 逆袭!Xbox One销量超PS4成英国游戏主机销售冠军
热门文章
- Python 常用函数 - Python入门教程
- 初识C++之运算符重载
- python制作加密工具_Python制作钉钉加密/解密工具
- php phpexcel用法,PHPExcel用法总结
- mysql workbench 1064_MySQL Workbench:查询错误(1064):第1行“ VISIBLE”附近的语?mysql-问答-阿里云开发者社区-阿里云...
- linux下使用odbc连接mysql_Linux环境下通过ODBC访问MSSql Server
- 权限管理系统_在Gitee狂揽11K Star!这个SpringCloud的权限管理系统你必须知道
- 天融信防火墙重置配置_天融信防火墙配置手册
- mysql官网 ab_MySQLAB同步
- 《软件项目管理(第二版)》期末考试试题总结/复习资料