Javascript排序算法之计数排序的实例


Posted in Javascript onApril 05, 2014

计数排序(Counting sort)是一种稳定的排序算法。计数排序使用一个额外的数组Count_arr,其中第i个元素是待排序数组Arr中值等于i的元素的个数。然后根据数组Count_arr来将Arr中的元素排到正确的位置。
分为四个步骤:
1.找出待排序的数组中最大和最小的元素
2.统计数组中每个值为i的元素出现的次数,存入数组Count_arr的第i项
3.对所有的计数累加(从Count_arr中的第一个元素开始,每一项和前一项相加)
4.反向遍历原数组:将每个元素i放在新数组的第Count_arr(i)项,每放一个元素就将Count_arr(i)减去1

实例:

/**
 * 计数排序是一个非基于比较的排序算法,
 * 该算法于1954年由 Harold H. Seward 提出。
 * 它的优势在于在对一定范围内的整数排序时,
 * 它的复杂度为Ο(n+k)(其中k是整数的范围),
 * 快于任何比较排序算法。
 *
 */function countSort(arr, min, max) {
    var i, z = 0, count = [];
    for (i = min; i <= max; i++) {
        count[i] = 0;
    }
    for (i=0; i < arr.length; i++) {
        count[arr[i]]++;
    }
    for (i = min; i <= max; i++) {
        while (count[i]-- > 0) {
            arr[z++] = i;
        }
    }
    return arr;
}
// test
var i, arr = [];
for (i = 0; i < 100; i++) {
    arr.push(Math.floor(Math.random() * (141)));
}
countSort(arr, 0, 140);
Javascript 相关文章推荐
fromCharCode和charCodeAt 方法
Dec 27 Javascript
慎用 somefunction.prototype 分析
Jun 02 Javascript
Extjs4 关于Store的一些操作(加载/回调/添加)
Apr 18 Javascript
解析dom中的children对象数组元素firstChild,lastChild的使用
Jul 10 Javascript
javascript实例--教你实现扑克牌洗牌功能
May 15 Javascript
jquery实现的Banner广告收缩效果代码
Sep 02 Javascript
基于jquery实现简单的手风琴特效
Nov 24 Javascript
js实现内容显示并使用json传输数据
Mar 16 Javascript
vue-cli脚手架-bulid下的配置文件
Mar 27 Javascript
原生JS实现的碰撞检测功能示例
May 18 Javascript
JS实现的视频弹幕效果示例
Aug 17 Javascript
Vue中key的作用示例代码详解
Jun 10 Javascript
JavaScript中的正则表达式简明总结
Apr 04 #Javascript
JavaScript格式化日期时间的方法和自定义格式化函数示例
Apr 04 #Javascript
Javascript排序算法之合并排序(归并排序)的2个例子
Apr 04 #Javascript
JQuery记住用户名和密码的具体实现
Apr 04 #Javascript
JS根据变量保存方法名并执行方法示例
Apr 04 #Javascript
JavaScript制作的可折叠弹出式菜单示例
Apr 04 #Javascript
JavaScript排序算法之希尔排序的2个实例
Apr 04 #Javascript
You might like
超强分页类2.0发布,支持自定义风格,默认4种显示模式
2007/01/02 PHP
PHP MPDF中文乱码的解决方式
2015/12/08 PHP
PHP文件操作实例总结
2016/09/27 PHP
ThinkPHP 3.2.2实现事务操作的方法
2017/05/05 PHP
PHP实现简易计算器功能
2020/08/28 PHP
深入聊聊Array的sort方法的使用技巧.详细点评protype.js中的sortBy方法
2007/04/12 Javascript
基于jQuery实现模拟页面加载进度条
2013/04/01 Javascript
新增加的内容是如何将div的scrollbar自动移动最下面
2014/01/02 Javascript
IE8中使用javascript动态加载CSS的解决方法
2014/06/17 Javascript
在JavaScript中操作时间之setYear()方法的使用
2015/06/12 Javascript
前端跨域的几种解决方式总结(推荐)
2017/08/16 Javascript
vue中echarts引入中国地图的案例
2020/07/28 Javascript
JavaScript setTimeout()基本用法有哪些
2020/11/04 Javascript
js 执行上下文和作用域的相关总结
2021/02/08 Javascript
[46:14]完美世界DOTA2联赛PWL S3 Magma vs INK ICE 第一场 12.11
2020/12/16 DOTA
实例讲解Python中SocketServer模块处理网络请求的用法
2016/06/28 Python
Python调用C++程序的方法详解
2017/01/24 Python
获取Django项目的全部url方法详解
2017/10/26 Python
python根据unicode判断语言类型实例代码
2018/01/17 Python
python utc datetime转换为时间戳的方法
2019/01/15 Python
Python将列表中的元素转化为数字并排序的示例
2019/12/25 Python
获取CSDN文章内容并转换为markdown文本的python
2020/09/06 Python
美国知名生活购物网站:Goop
2017/11/03 全球购物
临床医学大学生求职信
2013/09/28 职场文书
大学生个人推荐信范文
2013/11/25 职场文书
高中校园广播稿
2014/01/11 职场文书
感恩节活动方案
2014/01/27 职场文书
全神贯注教学反思
2014/02/03 职场文书
数控技校生自我鉴定
2014/04/19 职场文书
质量负责人任命书
2014/06/06 职场文书
个人存款证明书
2014/10/18 职场文书
迟到检讨书范文
2015/01/27 职场文书
超市采购员岗位职责
2015/04/07 职场文书
严以用权专题学习研讨会发言材料
2015/11/09 职场文书
简单了解 MySQL 中相关的锁
2021/05/25 MySQL
mysql 排序失效
2022/05/20 MySQL