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 相关文章推荐
JavaScript操作XML实例代码(获取新闻标题并分页,并分页)
May 25 Javascript
JavaScript中的迭代器和生成器详解
Oct 29 Javascript
JavaScript实现带缓冲效果的随屏滚动漂浮广告代码
Nov 06 Javascript
使用RequireJS库加载JavaScript模块的实例教程
Jun 06 Javascript
jQuery树控件zTree使用方法详解(一)
Feb 28 Javascript
webpack学习教程之publicPath路径问题详解
Jun 17 Javascript
详解VueJs中的V-bind指令
May 03 Javascript
Vue引入sass并配置全局变量的方法
Jun 27 Javascript
vue根据进入的路由进行原路返回的方法
Sep 26 Javascript
微信公众平台 发送模板消息(Java接口开发)
Apr 17 Javascript
全面解析JavaScript Module模式
Jul 24 Javascript
JavaScript中的执行环境和作用域链
Sep 04 Javascript
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
收音机史话 - 1960年代前后的DIY
2021/03/02 无线电
php学习笔记之 函数声明(二)
2011/06/09 PHP
php画图实例
2014/11/05 PHP
PHP获取当前相对于域名目录的方法
2015/06/26 PHP
利用javascript实现一些常用软件的下载导航
2009/08/03 Javascript
Javascript的匿名函数小结
2009/12/31 Javascript
js DataSet数据源处理代码
2010/03/29 Javascript
js固定DIV高度,超出部分自动添加滚动条的简单方法
2013/07/10 Javascript
最简单的tab切换实例代码
2016/05/13 Javascript
jQuery制作图片旋转效果
2017/02/02 Javascript
angular中实现控制器之间传递参数的方式
2017/04/24 Javascript
js学习总结之DOM2兼容处理顺序问题的解决方法
2017/07/27 Javascript
在vue中通过axios异步使用echarts的方法
2018/01/13 Javascript
解决vue build打包之后首页白屏的问题
2018/03/06 Javascript
JS简单实现查看文档创建日期、修改日期和文档大小的方法示例
2018/04/08 Javascript
python抓取文件夹的所有文件
2018/02/27 Python
mac安装scrapy并创建项目的实例讲解
2018/06/13 Python
python实现俄罗斯方块
2018/06/26 Python
Python使用pandas和xlsxwriter读写xlsx文件的方法示例
2019/04/09 Python
浅析python redis的连接及相关操作
2019/11/07 Python
浅析python,PyCharm,Anaconda三者之间的关系
2019/11/27 Python
Python Numpy数组扩展repeat和tile使用实例解析
2019/12/09 Python
在Pytorch中计算自己模型的FLOPs方式
2019/12/30 Python
python实现PCA降维的示例详解
2020/02/24 Python
python爬虫开发之使用python爬虫库requests,urllib与今日头条搜索功能爬取搜索内容实例
2020/03/10 Python
简单了解python关键字global nonlocal区别
2020/09/21 Python
阿玛瑞酒店中文官方网站:Amari.com
2018/02/13 全球购物
澳大利亚个性化儿童礼品网站:Bright Star Kids
2019/06/14 全球购物
澳大利亚在线消费电子产品商店:TobyDeals
2020/01/05 全球购物
美国滑板店:Tactics
2020/11/08 全球购物
群胜软件Java笔试题
2012/09/29 面试题
会计电算化专业毕业生自荐信
2013/12/20 职场文书
《风娃娃》教学反思
2014/04/19 职场文书
单身证明范本
2015/06/15 职场文书
电工实训心得体会
2016/01/14 职场文书
创业计划书之服装
2019/10/07 职场文书