JS实现的计数排序与基数排序算法示例


Posted in Javascript onDecember 04, 2017

本文实例讲述了JS实现的计数排序与基数排序算法。分享给大家供大家参考,具体如下:

计数排序

计数排序就是简单的桶排序,一个桶代表数组中一个数出现的个数,所以需要一个和数组数字范围一样大的辅助数组,一般用在范围小于100的排序,时间复杂度为O(n),空间复杂度为数组的数字范围。

/**
 * 范围在 start - end 之间的排序
 * 计数排序需要辅助数组,该辅助数组的长度是待排序数组的范围,所以一般用作范围小于100的排序
 */
function countSort(arr, start, end) {
  var len = arr.length;
  // 桶数组
  var suportArr = new Array(end - start + 1);
  // 结果数组
  var resArr = new Array(len);
  // 初始化桶数组
  for (i = 0; i < suportArr.length; i++) {
    suportArr[i] = 0;
  }
  // 待排序数组中的数组出现,在桶子对应位置+1代表这个数出现的个数+1了
  for (let i = 0; i < len; i++) {
    suportArr[arr[i]]++;
  }
   // 从第1项开始,桶数组加上前一个桶的个数,现在辅助数组的意义变成了每一项的排名了。
  for (let i = 1; i < suportArr.length; i++) {
    suportArr[i] += suportArr[i - 1];
  }
  // 根据辅助数组的排名,从后往前赋值
  for (let i = len - 1; i >= 0; i--) {
    resArr[suportArr[arr[i]] - 1] = arr[i];
    suportArr[arr[i]]--;
  }
  return resArr;
}

基数排序

基数排序是多躺的桶排序

var radix = 16; // 基数,可以为任何数,越大趟数越小,但是桶数越多,最好根据最大数字进行定义。
function _roundSort(arr, round, radix) {
  var buckets = new Array(radix);
  for (let i = 0; i < radix; i++) {
    buckets[i] = [];
  }
  // 将数组中的数放进对应的桶子中
  for (let i = 0; i < arr.length; i++) {
    let remainder = Math.floor(arr[i] / (radix ** (round - 1))) % radix;
    buckets[remainder].push(arr[i]);
  }
  // 将数组重新根据桶子进行排序
  var index = 0;
  for (let i = 0; i < buckets.length; i++) {
    for (let j = 0; j < buckets[i].length; j++) {
      arr[index++] = buckets[i][j];
    }
  }
}
function radixSort(arr, round) {
  for (let i = 1; i <= round; i++) {
    _roundSort(arr, i, radix);
  }
  return arr;
}
console.log(radixSort([10,5,5,50,0,155,4622,5,1,4,2154], 4));
Javascript 相关文章推荐
用jQuery技术实现Tab页界面之二
Sep 21 Javascript
原生javascript实现图片无缝滚动效果
Feb 12 Javascript
Bootstrap前端开发案例一
Jun 17 Javascript
jQuery图片渐变特效的简单实现
Jun 25 Javascript
Bootstrap优化站点资源、响应式图片、传送带使用详解3
Oct 14 Javascript
jquery.form.js异步提交表单详解
Apr 25 jQuery
详解vue-cli 脚手架项目-package.json
Jul 04 Javascript
vue router2.0二级路由的简单使用
Jul 05 Javascript
react同构实践之实现自己的同构模板
Mar 13 Javascript
React组件设计模式之组合组件应用实例分析
Apr 29 Javascript
JS 设计模式之:单例模式定义与实现方法浅析
May 06 Javascript
关于Vue中的options选项
Mar 22 Vue.js
JS 中document.write()的用法和清空的原因浅析
Dec 04 #Javascript
JavaScript实现省市联动过程中bug的解决方法
Dec 04 #Javascript
浅谈 vue 中的 watcher
Dec 04 #Javascript
vue中的计算属性的使用和vue实例的方法示例
Dec 04 #Javascript
Vue导出json数据到Excel电子表格的示例
Dec 04 #Javascript
微信小程序tabBar用法实例详解
Dec 04 #Javascript
详解如何实现一个简单的Node.js脚手架
Dec 04 #Javascript
You might like
php正则preg_replace_callback函数用法实例
2015/06/01 PHP
分享微信扫码支付开发遇到问题及解决方案-附Ecshop微信支付插件
2015/08/23 PHP
PHP利用imagick生成组合缩略图
2016/02/19 PHP
js中哈希表的几种用法总结
2014/01/28 Javascript
防止按钮在短时间内被多次点击的方法
2014/03/10 Javascript
跟我学Nodejs(一)--- Node.js简介及安装开发环境
2014/05/20 NodeJs
jquery比较简洁的软键盘特效实现方法
2015/03/19 Javascript
JavaScript转换二进制编码为ASCII码的方法
2015/04/16 Javascript
vue.js指令v-for使用及索引获取
2016/11/03 Javascript
判断颜色是否合法的正则表达式(详解)
2017/05/03 Javascript
vue.js项目 el-input 组件 监听回车键实现搜索功能示例
2018/08/25 Javascript
Python3.X 线程中信号量的使用方法示例
2017/07/24 Python
python difflib模块示例讲解
2017/09/13 Python
Python在不同目录下导入模块的实现方法
2017/10/27 Python
python 遍历目录(包括子目录)下所有文件的实例
2018/07/11 Python
python  Django中的apps.py的目的是什么
2018/10/15 Python
在Tensorflow中查看权重的实现
2020/01/24 Python
Python Django中的STATIC_URL 设置和使用方式
2020/03/27 Python
Python Map 函数的使用
2020/08/28 Python
python之语音识别speech模块
2020/09/09 Python
使用HTML5做的导航条详细步骤
2020/10/19 HTML / CSS
Laravel的加密解密与哈希实例讲解
2021/03/24 PHP
入党自我评价范文
2014/02/02 职场文书
美术指导助理求职信
2014/04/20 职场文书
我为党旗添光彩演讲稿
2014/09/10 职场文书
合作协议书模板2014
2014/09/26 职场文书
单位员工收入证明样本
2014/10/09 职场文书
2014年招商引资工作总结
2014/11/22 职场文书
委托公证书格式
2015/01/26 职场文书
2015年安全生产责任书
2015/01/30 职场文书
企业投资意向书
2015/05/09 职场文书
公积金具结保证书
2015/05/11 职场文书
教师听课学习心得体会
2016/01/15 职场文书
教你漂亮打印Pandas DataFrames和Series
2021/05/29 Python
CSS3实现列表无限滚动/轮播效果
2021/06/23 HTML / CSS
【海涛教你打DOTA】剑圣第一人称视角解说
2022/04/01 DOTA