数组的快速排序算法,和并归排序步骤基本类似。

都是先拆分,后合并。并归排序是:拆分容易,合并难。 快速排序是:拆分难,合并容易

要理解快速排序,首先要理解拆分逻辑

要素:找一个基准点,通过操作使得数列的左边全部都是小于他的数,右边全部都是大于他的数;

1、选中基准点,开始索引 i   ,结束索引  j

2、从数列右边开始往左边找,找到比基准点小的,交换位置 i++

3、从数列左边开始往右边找,找到比基准点大的,交换位置 j--

4、循环执行2、3,直到,i 不是小于 j

例如: 有数组  var arr = [30,24,5,58,18,36,12,42,39];

开始索引  i = 0;  结束索引 j = arr.length-1;    基准点  pivot = arr[i]  即为30

   则有如下代码

 

var arr = [30,24,5,58,18,36,12,42,39];
var i = 0, j = arr.length-1,pivot = arr[i]; while(i < j ){ //当最后结束时 i = j
//从右往左找,找到比基准点小等的就交换,交换后,基准点的索引变为 j
while(i < j && arr[j] > pivot )
j--; //排除已经满足条件的点
if(i < j ){
swap(i++,j,arr);
} //从左往右找,找到比基准点大的就交换,交换后,基准点的索引变为 i
while(i < j && arr[i] <= pivot)
i++; //排除已经满足条件的点
if(i < j ){
swap(i,j--,arr);
}
} function swap(a,b,arr){
console.log(a,b,arr[a],arr[b])
var temp = arr[a];
arr[a] = arr[b];
arr[b] = temp;
} console.log(i,arr); //基准点i,处理好的arr

  

以上代码就是快速排序的核心,如果将数列,不断以上面方式细分,直到分为单个元素。即最后的结果就是一个有序的数列

下面给出完整代码

	    var arr = [30,24,5,58,18,36,12,42,39];

		function Partition(arr,low,high){
var i = low,j = high,pivot = arr[i]; while(i < j ){
//从右往左找
while(i < j && arr[j] > pivot )
j--;
if(i < j ){
swap(i++,j,arr);
} //从左往右找
while(i < j && arr[i] <= pivot)
i++;
if(i < j ){
swap(i,j--,arr);
}
} return i; //返回基准元素位置
} function swap(a,b,arr){
console.log(a,b,arr[a],arr[b])
var temp = arr[a];
arr[a] = arr[b];
arr[b] = temp;
} function QuickSort(arr,low,high){
var mid;
if(low < high){
mid = Partition(arr,low,high); //返回基准元素位置
QuickSort(arr,low,mid-1); //左边快速排序
QuickSort(arr,mid+1,high); //右边快速排序
}
}
QuickSort(arr,0,arr.length-1);
console.log(arr);

  

优化扩展:

上面的Partition函数中,不管是从右往左,还是从左往右。都是跟pivot基准元素交换。。实际上,可以先直接左边和右边交换,最后再和基准元素交换,减少交换次数。代码如下

var arr = [30,24,5,58,18,36,12,42,39];
var i = 0, j = arr.length-1,pivot = arr[i];
var mid;
while(i < j ){ //当最后结束时 i = j
//从右往左找
while(i < j && arr[j] > pivot )
j--; //排除已经满足条件的点
//从左往右找
while(i < j && arr[i] <= pivot)
i++; //排除已经满足条件的点 //找到两个点,就相互交换
if(i < j ){
swap(i++,j--,arr);
}
} //最后将中间点和基准点交换
if(arr[i] > pivot){
mid = i-1;
swap(0,mid,arr);
}else{
mid = i;
swap(0,mid,arr);
} function swap(a,b,arr){
console.log(a,b,arr[a],arr[b])
var temp = arr[a];
arr[a] = arr[b];
arr[b] = temp;
} console.log(mid,arr); //基准点mid,处理好的arr

  

使用js的数组方法 , unshift 和push

使用unshift 和push实现,将数列的基准元素,左边全部小于他,右边全部大于他

           var arr = [30,24,5,58,18,36,12,42,39];
var i = 0, pivot = arr[0], arr2 = [pivot];
for(var j = 1; j < arr.length; j++ ){
if(arr[j] > pivot){
arr2.push(arr[j]);
}else{
arr2.unshift(arr[j]);
i++;
}
}
console.log(i,arr2);

  

使用 unshift和push实现的快速排序

		var arr = [30,24,5,58,18,36,12,42,39];

		function Partition(arr,low,high){
var i = low,pivot = arr[i];
var arr2 = [pivot];
for(var j = low+1; j <= high; j++){
if(arr[j] > pivot){
arr2.push(arr[j]);
}else{
arr2.unshift(arr[j]);
i++;
}
}
j = 0;
for(var k = low ; k <= high ; k++){
arr[k] = arr2[j++];
}
return i; //返回基准元素位置
} function QuickSort(arr,low,high){
var mid;
if(low < high){
mid = Partition(arr,low,high); //返回基准元素位置
QuickSort(arr,low,mid-1); //左边快速排序
QuickSort(arr,mid+1,high); //右边快速排序
}
}
QuickSort(arr,0,arr.length-1);
console.log(arr);

  

js快速排序算法解析的更多相关文章

  1. js快速排序算法

    真正的快速排序算法一: function quickSort(array){ function sort(prev, numsize){ var nonius = prev; var j = nums ...

  2. js 快速排序算法

    Array.prototype.quickSort = function() { var len = this.length; if(len < 2) return this; var left ...

  3. 结构-行为-样式-Js排序算法之 快速排序

    快速排序算法,是我的算法系列博客中的第二个Js实现的算法,主要思路:    在一个数组中随机取一个数(一般都取第一个或者最后一个),使这个数与数组中其他数进行比较,如果比它大就放到它的右边,比它小就放 ...

  4. js排序算法05——快速排序

    终于到了传说中的快速排序算法了,快速排序的思想和归并排序一样,都是采用分治思想,不同之处在于归并每次将数组一分为二,最后将小的数组进行比较,合并为大数组.快排是每次找一个主元,也就是基准数,按照这个基 ...

  5. Peterson算法与Dekker算法解析

    进来Bear正在学习巩固并行的基础知识,所以写下这篇基础的有关并行算法的文章. 在讲述两个算法之前,需要明确一些概念性的问题, Race Condition(竞争条件),Situations  lik ...

  6. python常见排序算法解析

    python——常见排序算法解析   算法是程序员的灵魂. 下面的博文是我整理的感觉还不错的算法实现 原理的理解是最重要的,我会常回来看看,并坚持每天刷leetcode 本篇主要实现九(八)大排序算法 ...

  7. Learn Algorithms With Javascript - 基于 Js 进行算法学习

    基于 javascript 学习并实现常用的经典算法,欢迎对算法和数学感兴趣的 Js 开发者参与,一起学习共同进步. 算法实现 排序 插入排序 sort/lib/insertion-sort.js 希 ...

  8. Js常见算法实现汇总

    /*去重*/ <script> function delRepeat(arr){ var newArray=new Array(); var len=arr.length; for(var ...

  9. 总结下js排序算法和乱序算法

    其实本人最怕的就是算法,大学算法课就感觉老师在讲天书,而且对于前端来说,算法在实际的应用中实在是很有限.毕竟算法要依靠大量的数据为基础才能发挥出算法的效率,就浏览器那性能,......是吧,退一万步说 ...

随机推荐

  1. Docker简介及Linux下安装

    什么是Docker? Docker是一个开源的引擎,可以轻松的为任何应用创建一个轻量级的.可移植的.自给自足的容器.开发者在笔记本上编译测试通过的容器可以批量地在生产环境中部署,包括VMs(虚拟机). ...

  2. Python把两个列表合成一个字典

    简单粗暴上代码 A= [] B = [] C= dict(map(lambda x,y:[x,y],A,B)) 酱紫,就合成了一个字典

  3. DB2 的代理 (agent)

    DB2 的代理 (agent) 是位于 DB2 服务器中的服务于应用程序请求的一些进程或线程.当有外部应用程序连接至 DB2 实例提出访问请求时,DB2 的代理就会被激活去应答这些请求.一般 DB2 ...

  4. MyEclipse中同时启动两个tomcat

    开发的时候,有些时候需要同时启动两个项目.首先配置tomcat,方法如下:(转载自:http://bendan123812.iteye.com/blog/1716789) 一.把Tomcat复制一份并 ...

  5. 二叉苹果树|codevs5565|luoguP2015|树形DP|Elena

    二叉苹果树 题目描述 有一棵苹果树,如果树枝有分叉,一定是分2叉(就是说没有只有1个儿子的结点) 这棵树共有N个结点(叶子点或者树枝分叉点),编号为1-N,树根编号一定是1. 我们用一根树枝两端连接的 ...

  6. ES6 import

    ES6标准发布后,module成为标准,标准的使用是以export指令导出接口,以import引入模块,但是在我们一贯的node模块中,我们采用的是CommonJS规范,使用require引入模块,使 ...

  7. class="no-js"

    这是什么意思?看了外网的解释,比较明白了.(When Modernizr runs, it removes the "no-js" class and replaces it wi ...

  8. Vue SSR 配合Java的Javascript引擎j2v8实现服务端渲染3配置webpack支持ssr

    安装 cross-env yarn add -D cross-env 安装 html-webpack-plugin yarn add -D html-webpack-plugin 安装 webpack ...

  9. iOS 动画学习之视图控制器转场动画

    一.概述 1.系统会创建一个转场相关的上下文对象,传递到动画执行器的animateTransition:和transitionDuration:方法,同样,也会传递到交互Controller的star ...

  10. [dpdk] dpdk编译成动态库使用 -- PCI port自动发现与pmd动态加载

    1.  修改配置文件 .conf, 设置如下变量的值. [root@D129 x86_64-native-linuxapp-gcc]# cat dpdk/x86_64-native-linuxapp- ...