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 相关文章推荐
jquery 入门教程 [翻译] 推荐
Aug 17 Javascript
基于jQuery的仿flash的广告轮播代码
Nov 04 Javascript
JQUERY dialog的用法详细解析
Dec 19 Javascript
jquery UI Datepicker时间控件的使用方法(加强版)
Nov 07 Javascript
JS实现自动轮播图效果(自适应屏幕宽度+手机触屏滑动)
Jun 19 Javascript
javascript流程控制语句集合
Sep 18 Javascript
基于百度地图api清除指定覆盖物(Overlay)的方法
Jan 26 Javascript
Java设计中的Builder模式的介绍
Mar 22 Javascript
微信小程序实时聊天WebSocket
Jul 05 Javascript
解决mpvue + vuex 开发微信小程序vuex辅助函数mapState、mapGetters不可用问题
Aug 03 Javascript
vue-cli 默认路由再子路由选中下的选中状态问题及解决代码
Sep 06 Javascript
js实现鼠标切换图片(无定时器)
Jan 27 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的简单采集数据入库程序【续篇】
2014/07/30 PHP
微信公众平台之快递查询功能用法实例
2015/04/14 PHP
php计算整个目录大小的方法
2015/06/19 PHP
jquery+thinkphp实现跨域抓取数据的方法
2016/10/15 PHP
thinkPHP5.0框架URL访问方法详解
2017/03/18 PHP
laravel ORM 只开启created_at的几种方法总结
2018/01/29 PHP
锋利的jQuery jQuery中的DOM操作
2010/03/21 Javascript
js中各浏览器中鼠标按键值的差异
2011/04/07 Javascript
前台js调用后台方法示例
2013/12/02 Javascript
JQuery以JSON方式提交数据到服务端示例代码
2014/05/05 Javascript
2种jQuery 实现刮刮卡效果
2015/02/01 Javascript
JavaScript中通过提示框跳转页面的方法
2016/02/14 Javascript
jQuery插件jqGrid动态获取列和列字段的方法
2017/03/03 Javascript
vue中如何让子组件修改父组件数据
2018/06/14 Javascript
js逆向解密之网络爬虫
2019/05/30 Javascript
如何使用webpack打包一个库library的方法步骤
2019/12/18 Javascript
ng-alain的sf如何自定义部件的流程
2020/06/12 Javascript
[08:17]Ti9 现场cosplay
2019/09/10 DOTA
Python中super关键字用法实例分析
2015/05/28 Python
python银行系统实现源码
2019/10/25 Python
DJango的创建和使用详解(默认数据库sqlite3)
2019/11/18 Python
详解如何用HTML5 Canvas API控制图片的缩放变换
2016/03/22 HTML / CSS
施华洛世奇德国官网:SWAROVSKI德国
2017/02/01 全球购物
狼和鹿教学反思
2014/02/05 职场文书
初三新学期计划书
2014/05/03 职场文书
考察现实表现材料
2014/05/19 职场文书
我爱我校演讲稿
2014/05/21 职场文书
中学教师师德承诺书
2014/05/23 职场文书
社区维稳工作方案
2014/06/06 职场文书
车贷收入证明范本
2014/09/14 职场文书
平安家庭事迹材料
2014/12/20 职场文书
试用期转正工作总结2015
2015/05/28 职场文书
基于PyTorch实现一个简单的CNN图像分类器
2021/05/29 Python
教你使用一行Python代码玩遍童年的小游戏
2021/08/23 Python
MySql中的json_extract函数处理json字段详情
2022/06/05 MySQL
Android Gradle 插件自定义Plugin实现注意事项
2022/06/16 Java/Android