当前位置:
首页 > temp > JavaScript教程 >
-
快速排序(JS实现)
思想
快速排序的基本思想是选择数组中的一个元素作为关键字,通过一趟排序,把待排序的数组分成两个部分,其中左边的部分比所有关键字小,右边的部分比所有关键字大。然后再分别对左右两边的数据作此重复操作,直到所有元素都有序,就得到了一个完全有序的数组。
来看一个例子,以数组[4, 5, 2, 7, 3, 1, 6, 8]为例,我们选中数组最左边的元素为关键字pivot
动态图如下,动态图使用20个元素的无序数组来演示。其中灰色背景为当前正在排序的子数组,橙色为当前pivot,为方便演示,使用交换元素的方式体现指针位置。
JS实现
代码如下:
const quickSort = (array)=>{
quick(array, 0, array.length - 1)
}
const quick = (array, left, right)=>{
if(left < right){
let index = getIndex(array, left, right);
quick(array, left, index-1)
quick(array, index+1, right)
}
}
const getIndex = (array, leftPoint, rightPoint)=>{
let pivot = array[leftPoint];
while(leftPoint < rightPoint){
while(leftPoint < rightPoint && array[rightPoint] >= pivot) {
rightPoint--;
}
array[leftPoint] = array[rightPoint]
// swap(array, leftPoint, rightPoint) //使用swap,则与动态图演示效果完全一致
while(leftPoint < rightPoint && array[leftPoint] <= pivot) {
leftPoint++;
}
array[rightPoint] = array[leftPoint]
// swap(array, leftPoint, rightPoint)
}
array[leftPoint] = pivot
return leftPoint;
}
const swap = (array, index1, index2)=>{
var aux = array[index1];
array.splice(index1, 1, array[index2])
array.splice(index2, 1, aux)
}
const createNonSortedArray = (size)=>{
var array = new Array();
for (var i = size; i > 0; i--) {
//array.push(parseInt(Math.random()*100));
array.push(i*(100/size));
array.sort(function() {
return (0.5-Math.random());
});
}
return array;
}
var arr = createNonSortedArray(20);
quickSort(arr)
console.log(arr) //[5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95, 100]
时间复杂度
快速排序很明显用了分治的思想,关键在于选择的pivot,如果每次都能把数据平分成两半,这样递归树的深度就是logN,这样快排的时间复杂度为O(NlogN)。
而如果每次pivot把数组分成一部分空,一部分为所有数据,那么这时递归树的深度就是n-1,这样时间复杂度就变成了O(N^2)。
根据以上的时间复杂度分析,我们发现如果一个数据完全有序,那么使用咱们上面的快速排序算法就是最差的情况,所以怎么选择pivot就成了优化快速排序的重点了,如果继续使用上面的算法,那么我们可以随机选择pivot来代替数组首元素作为pivot的方式。
本文链接:https://www.cnblogs.com/EaVango/p/14769230.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数