JS排序之快速排序详解


Posted in Javascript onApril 08, 2017

本文为大家分享了JS快速排序的具体代码,供大家参考,具体内容如下

说明

时间复杂度指的是一个算法执行所耗费的时间
空间复杂度指运行完一个程序所需内存的大小
稳定指,如果a=b,a在b的前面,排序后a仍然在b的前面
不稳定指,如果a=b,a在b的前面,排序后可能会交换位置

--JS快速排序--

原理

从数组中选定一个基数,然后把数组中的每一项与此基数做比较,小的放入一个新数组,大的放入另外一个新数组。然后再采用这样的方法操作新数组。直到所有子集只剩下一个元素,排序完成。

时间复杂度,空间复杂度,稳定性

  • 平均时间复杂度O(nlogn)
  • 最好情况O(nlogn)
  • 最差情况O(n*n)
  • 空间复杂度O(logn)
  • 稳定性:不稳定

快速排序的写法

var examplearr=[8,94,15,88,55,76,21,39];
function fastsort(arr){
  if(arr.length<2){
    return arr;
  }
  var left=[];
  var right=[];
  var pivotIndex=Math.floor(arr.length/2);
  var pivot=arr.splice(pivotIndex,1)[0];
  for(i=0;i<arr.length;i++){
    if(arr[i]<pivot){
      left.push(arr[i]);
    }else{
      right.push(arr[i])
    }
  }
  return fastsort(left).concat([pivot],fastsort(right));
}
console.log(fastsort(examplearr));

解析

pivotIndex是将数组的长度除2向下取整得到的一个数值,数组的长度是不断减半的,所以最后它的值为0

pivot是利用splice方法从数组里获取一个基数

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 三种创建对象的方法
Oct 16 Javascript
jquery+json实现的搜索加分页效果
Mar 31 Javascript
js将long日期格式转换为标准日期格式实现思路
Apr 07 Javascript
javascript获取隐藏元素(display:none)的高度和宽度的方法
Jun 06 Javascript
jQuery EasyUI datagrid实现本地分页的方法
Feb 13 Javascript
动态JavaScript所造成一些你不知道的危害
Sep 25 Javascript
Angular2 组件通信的实例代码
Jun 23 Javascript
利用vue + element实现表格分页和前端搜索的方法
Dec 25 Javascript
用react-redux实现react组件之间数据共享的方法
Jun 08 Javascript
jQuery 选择方法及$(this)用法实例分析
May 19 jQuery
详解Typescript 内置的模块导入兼容方式
May 31 Javascript
jQuery实现简单轮播图效果
Dec 27 jQuery
JS排序之选择排序详解
Apr 08 #Javascript
Vue异步组件使用详解
Apr 08 #Javascript
利用jQuery解析获取JSON数据
Apr 08 #jQuery
AngularJS $http模块POST请求实现
Apr 08 #Javascript
node.js实现登录注册页面
Apr 08 #Javascript
详解vue2路由vue-router配置(懒加载)
Apr 08 #Javascript
js仿微信公众平台打标签功能
Apr 08 #Javascript
You might like
php 按指定元素值去除数组元素的实现方法
2011/11/04 PHP
教你php如何实现验证码
2016/01/20 PHP
Yii框架多语言站点配置方法分析【中文/英文切换站点】
2020/04/07 PHP
取键盘键位ASCII码的网页
2007/07/30 Javascript
用Javascript实现锚点(Anchor)间平滑跳转
2009/09/08 Javascript
使用Firebug对js进行断点调试的图文方法
2011/04/02 Javascript
JavaScript中的noscript元素属性位置及作用介绍
2013/04/11 Javascript
jquery实现弹出div,始终显示在屏幕正中间的简单实例
2014/03/08 Javascript
javascipt:filter过滤介绍及使用
2014/09/10 Javascript
jQuery+ajax中getJSON() 用法实例
2014/12/22 Javascript
JavaScript实现点击单选按钮改变输入框中文本域内容的方法
2015/08/12 Javascript
JavaScript数据结构与算法之链表
2016/01/29 Javascript
原生js制作日历控件实例分享
2016/04/06 Javascript
利用js+css+html实现固定table的列头不动
2016/12/08 Javascript
jQuery实现select模糊查询(反射机制)
2017/01/14 Javascript
Angular2学习教程之TemplateRef和ViewContainerRef详解
2017/05/25 Javascript
10个在JavaScript开发中常遇到的BUG
2017/12/18 Javascript
在Vue项目中引入腾讯验证码服务的教程
2018/04/03 Javascript
Vue 获取数组键名的方法
2018/06/21 Javascript
Element-UI踩坑之Pagination组件的使用
2018/10/29 Javascript
教你搭建按需加载的Vue组件库(小结)
2019/07/29 Javascript
Nuxt使用Vuex的方法示例
2019/09/06 Javascript
简单了解vue 插值表达式Mustache
2020/07/22 Javascript
axios解决高并发的方法:axios.all()与axios.spread()的操作
2020/11/09 Javascript
在Windows服务器下用Apache和mod_wsgi配置Python应用的教程
2015/05/06 Python
Python的Asyncore异步Socket模块及实现端口转发的例子
2016/06/14 Python
python 读取dicom文件,生成info.txt和raw文件的方法
2019/01/24 Python
python+selenium 定位到元素,无法点击的解决方法
2019/01/30 Python
在Python 中同一个类两个函数间变量的调用方法
2019/01/31 Python
Python图像处理库PIL中图像格式转换的实现
2020/02/26 Python
python3爬虫中多线程进行解锁操作实例
2020/11/25 Python
html5实现完美兼容各大浏览器的播放器
2014/12/26 HTML / CSS
Baracuta官方网站:Harrington夹克,G9,G4,G10等
2018/03/06 全球购物
群众路线对照检查材料
2014/09/22 职场文书
Win11黑色桌面背景怎么办?Win11黑色壁纸解决方法汇总
2022/04/05 数码科技
MySQL表字段数量限制及行大小限制详情
2022/07/23 MySQL