JavaScript算法系列之快速排序(Quicksort)算法实例详解


Posted in Javascript onSeptember 04, 2016

"快速排序"的思想很简单,整个排序过程只需要三步:

(1)在数据集之中,选择一个元素作为"基准"(pivot)。

(2)所有小于"基准"的元素,都移到"基准"的左边;所有大于"基准"的元素,都移到"基准"的右边。

(3)对"基准"左边和右边的两个子集,不断重复第一步和第二步,直到所有子集只剩下一个元素为止。

举例来说,现在有一个数据集{85, 24, 63, 45, 17, 31, 96, 50},怎么对其排序呢?

第一步,选择中间的元素45作为"基准"。(基准值可以任意选择,但是选择中间的值比较容易理解。)

JavaScript算法系列之快速排序(Quicksort)算法实例详解

第二步,按照顺序,将每个元素与"基准"进行比较,形成两个子集,一个"小于45",另一个"大于等于45"。

JavaScript算法系列之快速排序(Quicksort)算法实例详解

第三步,对两个子集不断重复第一步和第二步,直到所有子集只剩下一个元素为止。

JavaScript算法系列之快速排序(Quicksort)算法实例详解

JavaScript算法系列之快速排序(Quicksort)算法实例详解

JavaScript算法系列之快速排序(Quicksort)算法实例详解

JavaScript算法系列之快速排序(Quicksort)算法实例详解

下面参照网上的资料(这里和这里),用Javascript语言实现上面的算法。

首先,定义一个quickSort函数,它的参数是一个数组。

var quickSort = function(arr) {
};

然后,检查数组的元素个数,如果小于等于1,就返回。

var quickSort = function(arr) {
if (arr.length <= 1) { return arr; }
};

接着,选择"基准"(pivot),并将其与原数组分离,再定义两个空数组,用来存放一左一右的两个子集。

var quickSort = function(arr) {
if (arr.length <= 1) { return arr; }

var pivotIndex = Math.floor(arr.length / 2) ;

var pivot = arr.splice(pivotIndex, 1)[0];

var left = [];

var right = [];
};

然后,开始遍历数组,小于"基准"的元素放入左边的子集,大于基准的元素放入右边的子集。

var quickSort = function(arr) {
if (arr.length <= 1) { return arr; }

var pivotIndex = Math.floor(arr.length / 2) ;

var pivot = arr.splice(pivotIndex, 1)[0];

var left = [];

var right = [];

for (var i = 0; i < arr.length; i++){


if (arr[i] < pivot) {



left.push(arr[i]);


} else {



right.push(arr[i]);


}

}
};

最后,使用递归不断重复这个过程,就可以得到排序后的数组。

var quickSort = function(arr) {
if (arr.length <= 1) { return arr; }

var pivotIndex = Math.floor(arr.length / 2);

var pivot = arr.splice(pivotIndex, 1)[0];

var left = [];

var right = [];

for (var i = 0; i < arr.length; i++){


if (arr[i] < pivot) {



left.push(arr[i]);


} else {



right.push(arr[i]);


}

}

return quickSort(left).concat([pivot], quickSort(right));
};

使用的时候,直接调用quickSort()就行了。

JavaScript算法系列之快速排序(Quicksort)算法实例详解

以上所述是小编给大家介绍的JavaScript算法系列之快速排序(Quicksort)算法实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript 使用技巧精萃(.net html
Apr 25 Javascript
基于jQuery仿淘宝产品图片放大镜代码分享
Jun 23 Javascript
jQuery代码实现图片墙自动+手动淡入淡出切换效果
May 09 Javascript
每日十条JavaScript经验技巧(一)
Jun 23 Javascript
前端框架Vue.js中Directive知识详解
Sep 12 Javascript
详解AngularJS验证、过滤器、指令
Jan 04 Javascript
实现一个简单的vue无限加载指令方法
Jan 10 Javascript
详解Vue监听数据变化原理
Mar 08 Javascript
一篇看懂vuejs的状态管理神器 vuex状态管理模式
Apr 20 Javascript
使用Browserify来实现CommonJS的浏览器加载方法
May 14 Javascript
vue2.x select2 指令封装详解
Oct 12 Javascript
利用Node.js检测端口是否被占用的方法
Dec 07 Javascript
jQuery中ScrollTo用法示例
Sep 04 #Javascript
jQuery与JS加载事件用法分析
Sep 04 #Javascript
jQuery轮播图效果精简版完整示例
Sep 04 #Javascript
jQuery实现最简单的切换图效果【可兼容IE6、火狐、谷歌、opera等】
Sep 04 #Javascript
jQuery实现的自定义弹出层效果实例详解
Sep 04 #Javascript
JS简单实现仿百度控制台输出信息效果
Sep 04 #Javascript
把多个JavaScript函数绑定到onload事件处理函数上的方法
Sep 04 #Javascript
You might like
MySQL的FIND_IN_SET函数使用方法分享
2012/03/27 PHP
dedecms中使用php语句指南
2014/11/13 PHP
PHP编写登录验证码功能 附调用方法
2016/05/19 PHP
php实现水印文字和缩略图的方法示例
2016/12/29 PHP
PHP编程一定要改掉的5个不良习惯
2020/09/18 PHP
JavaScript 处理Iframe自适应高度(同或不同域名下)
2013/03/29 Javascript
原生javascript实现无间缝滚动示例
2014/01/28 Javascript
jquery控制显示服务器生成的图片流
2015/08/04 Javascript
JS+CSS实现美化的下拉列表框效果
2015/08/11 Javascript
jQuery视差滚动效果网页实现方法经验总结
2016/09/29 Javascript
判断颜色是否合法的正则表达式(详解)
2017/05/03 Javascript
使用Node.js实现简易MVC框架的方法
2017/08/07 Javascript
使用socket.io制做简易WEB聊天室
2018/01/02 Javascript
webpack本地开发环境无法用IP访问的解决方法
2018/03/20 Javascript
vue自定义一个v-model的实现代码
2018/06/21 Javascript
jQuery实现的3D版图片轮播示例【滑动轮播】
2019/01/18 jQuery
vue-router 中 meta的用法详解
2019/11/01 Javascript
Vue状态模式实现窗口停靠功能(灵动、自由, 管理后台Admin界面)
2020/03/06 Javascript
javaScript代码飘红报错看不懂?读完这篇文章再试试
2020/08/19 Javascript
[01:32]2016国际邀请赛中国区预选赛CDEC战队教练采访
2016/06/26 DOTA
Python 数据结构之旋转链表
2017/02/25 Python
python 如何快速找出两个电子表中数据的差异
2017/05/26 Python
python 与服务器的共享文件夹交互方法
2018/12/27 Python
python中matplotlib条件背景颜色的实现
2019/09/02 Python
python实现局域网内实时通信代码
2019/12/22 Python
Python3.7在anaconda里面使用IDLE编译器的步骤详解
2020/04/29 Python
canvas实现烟花的示例代码
2020/01/16 HTML / CSS
我有一个char * 型指针正巧指向一些int 型变量, 我想跳过它们。 为什么如下的代码((int *)p)++; 不行?
2013/05/09 面试题
物流专业大学的自我评价
2014/01/11 职场文书
公司会计岗位职责
2014/02/13 职场文书
售房协议书范本2014
2014/10/23 职场文书
2014年接待工作总结
2014/11/26 职场文书
六一文艺汇演主持词
2015/06/30 职场文书
环境卫生标语
2015/08/03 职场文书
开发一个封装iframe的vue组件
2021/03/29 Vue.js
angular异步验证器防抖实例详解
2022/03/31 Javascript