博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
五分钟学会一个有意思的排序:计数排序
阅读量:6711 次
发布时间:2019-06-25

本文共 1100 字,大约阅读时间需要 3 分钟。

由于LeetCode上的算法题很多涉及到一些基础的数据结构,为了更好的理解后续更新的一些复杂题目的动画,推出一个新系列 -----《图解数据结构》,主要使用动画来描述常见的数据结构和算法。本系列包括十大排序、堆、队列、树、并查集、图等等大概几十篇。

你可以在公众号 五分钟学算法 获取更多排序内容

计数排序

计数排序是一种非基于比较的排序算法,其空间复杂度和时间复杂度均为O(n+k),其中k是整数的范围。基于比较的排序算法时间复杂度最小是O(nlogn)的。该算法于1954年由 Harold H. Seward 提出。

计数排序的核心在于将输入的数据值转化为键存储在额外开辟的数组空间中。作为一种线性时间复杂度的排序,计数排序要求输入的数据必须是有确定范围的整数

算法步骤

  1. 花O(n)的时间扫描一下整个序列 A,获取最小值 min 和最大值 max

  2. 开辟一块新的空间创建新的数组 B,长度为 ( max - min + 1)

  3. 数组 B 中 index 的元素记录的值是 A 中某元素出现的次数

  4. 最后输出目标整数序列,具体的逻辑是遍历数组 B,输出相应元素以及对应的个数

算法演示

排序动画过程解释

  1. 首先,扫描一下整个序列

  2. 获得最小值为 2 ,最大值为 7

  3. 新建数组包含 2~7 的元素

  4. 再次扫描序列,将序列的值放置在新建数组中

  5. 扫描数字 5,数组中 index 为 3 的值为 5,次数为 1

  6. 扫描数字 3,数组中 index 为 1 的值为 3,次数为 1

  7. 扫描数字 4,数组中 index 为 2 的值为 4,次数为 1

  8. 扫描数字 7,数组中 index 为 5 的值为 7,次数为 1

  9. 扫描数字 2,数组中 index 为 0 的值为 2,次数为 1

  10. 扫描数字 4,数组中 index 为 2 的值为 4,次数为 2

  11. 扫描数字 3,数组中 index 为 1 的值为 3,次数为 2

  12. 按照这种节奏,扫描结束后,新建数组中存放了整个序列以及每个数字出现的次数

  13. 最后输出目标整数序列

  14. 输出数字 2,同时数组中 index 为 0 的值为 2 的元素次数变为 0

  15. 输出数字 3,同时数组中 index 为 1 的值为 3 的元素次数变为 1

  16. 同样的操作,整个序列就完全输出了

代码实现

为了更好的让读者用自己熟悉的编程语言来理解动画,笔者将贴出多种编程语言的参考代码,代码全部来源于网上。

Go代码实现

Java代码实现

Python代码实现

JavaScript代码实现

如果你是iOS开发者,可以在GitHub上 获取更直观可调试运行的源码。

你可以在公众号 五分钟学算法 获取更多排序内容

转载地址:http://dlalo.baihongyu.com/

你可能感兴趣的文章
socket中的SO_REUSEADDR
查看>>
Android中Bitmap、Drawable、byte[]转换
查看>>
[杂记]是否有必要精通unix的shell语法?
查看>>
Oracle 数据类型及存储方式(二)
查看>>
UNIX时间戳的应用-JAVA
查看>>
Intelij 中javax.servlet.http.HttpServlet包导不进来
查看>>
dynamic disk无损转为basic disk
查看>>
SoftReference缓存图片
查看>>
PHP关闭(禁止)脚本错误提示的方法及让脚本错误提示输出为日志文件的方法
查看>>
URAL 1013 K-based Numbers. Version 3
查看>>
[转]请记住别拿自己跟别人比较
查看>>
Boost简介
查看>>
计算机常用端口一览表:
查看>>
Android 自带图标库 android.R.drawable
查看>>
HTTP Error: status code 302. I/O Error: Error #2038. ckfinder报错
查看>>
java.util.Date和java.sql.Date的区别和相互转化
查看>>
selenium面试题总结
查看>>
本次孩子流感总结
查看>>
Baby Ming and Matrix games(dfs计算表达式)
查看>>
eclipse代码提示框背景色改动
查看>>