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 相关文章推荐
javascript css float属性的特殊写法
Nov 13 Javascript
js日期相关函数总结分享
Oct 15 Javascript
JS控制图片翻转示例代码(兼容firefox,ie,chrome)
Dec 19 Javascript
探寻Javascript执行效率问题
Nov 12 Javascript
jQuery中:password选择器用法实例
Jan 03 Javascript
AngularJS的一些基本样式初窥
Jul 27 Javascript
JavaScript类型系统之布尔Boolean类型详解
Jun 26 Javascript
微信小程序 常见问题总结(4058,40013)及解决办法
Jan 11 Javascript
JS实现数组去重复值的方法示例
Feb 18 Javascript
JavaScript事件委托原理与用法实例分析
Jun 07 Javascript
vue-cli3 配置开发与测试环境详解
May 17 Javascript
微信小程序云开发实现增删改查功能
May 17 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
PHP mkdir()定义和用法
2009/01/14 PHP
仿Aspnetpager的一个PHP分页类代码 附源码下载
2012/10/08 PHP
php实现的九九乘法口诀表简洁版
2014/07/28 PHP
php表单敏感字符过滤类
2014/12/08 PHP
PHP实现的登录页面信息提示功能示例
2017/07/24 PHP
PHP实现的redis主从数据库状态检测功能示例
2017/07/20 PHP
laravel框架模型中非静态方法也能静态调用的原理分析
2019/11/23 PHP
firebug的一个有趣现象介绍
2011/11/30 Javascript
javascript原始值和对象引用实例分析
2015/04/25 Javascript
深入学习JavaScript中的Rest参数和参数默认值
2015/07/28 Javascript
PHP+jquery+ajax实现分页
2016/12/09 Javascript
JS去除重复并统计数量的实现方法
2016/12/15 Javascript
原生js二级联动效果
2017/06/20 Javascript
Easyui在treegrid添加控件的实现方法
2017/06/23 Javascript
Javascript实现时间倒计时效果
2017/07/15 Javascript
vue微信分享 vue实现当前页面分享其他页面
2017/12/02 Javascript
Vue-cli配置打包文件本地使用的教程图解
2018/08/02 Javascript
详解vue使用vue-layer-mobile组件实现toast,loading效果
2018/08/31 Javascript
详解babel升级到7.X采坑总结
2019/05/12 Javascript
js+canvas实现两张图片合并成一张图片的方法
2019/11/01 Javascript
解决vue-photo-preview 异步图片放大失效的问题
2020/07/29 Javascript
Vue 同步异步存值取值实现案例
2020/08/05 Javascript
微信小程序实现锚点跳转
2020/11/23 Javascript
python pandas获取csv指定行 列的操作方法
2019/07/12 Python
win10系统Anaconda和Pycharm的Tensorflow2.0之CPU和GPU版本安装教程
2019/12/03 Python
Pyinstaller 打包发布经验总结
2020/06/02 Python
浅析HTML5中header标签的用法
2016/06/24 HTML / CSS
意大利大型购物中心:Oliviero.it
2017/10/19 全球购物
上班离岗检讨书
2014/01/27 职场文书
秋季校运动会广播稿
2014/02/23 职场文书
十佳文明家庭事迹
2014/05/25 职场文书
大学生志愿者活动总结
2014/06/27 职场文书
优秀学生主要事迹怎么写
2015/11/04 职场文书
python实现自动清理文件夹旧文件
2021/05/10 Python
船舶调度指挥系统——助力智慧海事
2022/02/18 无线电
MySQL约束(创建表时的各种条件说明)
2022/06/21 MySQL