其基本思路应该是排成两部分单独记录,确定枢轴,实施枢轴到左侧值我们都小于枢轴值。枢轴向右大于枢轴值。这样子不断递归下去


function quicksort(arr,low,high){
var pivot;
if(low < high){
pivot = partition(arr,low,high);
quicksort(arr,low,pivot-1);
quicksort(arr,pivot+1,high);
}
return arr;
}

这个就是快排的入口函数。出现了partition方法。它的作用就是找出记录中的keyword,也就是枢轴


function partition(arr,low,high){
1. var pivot = arr[low];
2. while(low <= high){
3. while(low <= high && arr[high] >= pivot){
4. high--;
5. }
6. swap(arr,low,high);
7. while(low <= high && arr[low] < pivot){
8. low++;
9. }
10 swap(arr,low,high);
11 }
12 return low;
13 }

事实上它的思想也是挺简单的。比方你有这样一系列数字:5 1 9 3 7 4 8 6 2。我们这里仅仅计算第一趟快排,其它仅仅是递归下去,思路是一致的。

  1. 代码行1把数字列的第一个元素5作为为枢轴,跟最后一个元素2比較;
  2. 一比較不符合代码行3 arr[high] >= pivot。所以就运行交换两个位置的值;
  3. 如今的数字列为2 1 9 3 7 4 8 6 5
  4. 运行代码行7得出2 1都小于枢轴5继续循环,可是到了9时就不满足条件退出了循环。
  5. 运行交换后数字列为2 1 5 3 7 4 8 6 9
  6. 这个时候low为3 high为9 满足代码行2的循环条件继续依照前面步骤1~5运行
  7. 最后第一趟数字列为2 1 4 3 5 7 8 6 9
  8. 枢轴5的左边的值2 1 4 3都比它小。右边的值7 8 6 9都比它大

最后有一个函数就是交换函数的


function swap(arr,low,high){
var temp;
temp = arr[low];
arr[low] = arr[high];
arr[high] = temp;
}

这个函数实现起来还是比較简单的

假设不太了解快排方法的人能够去看《大话数据结构》,写得浅显易懂。

还有就是事实上能够用闭包的方法封装partition和swap方法,揭露quicksort接口到该方法向外界

版权声明:本文博客原创文章,博客,未经同意,不得转载。

最新文章

  1. windows10简单试用(多图,连薛定谔的猫都杀死了)
  2. 自定义制作iso镜像
  3. 高级查询---嵌套and分页
  4. C#设计模式-桥接模式
  5. Random Javascript code snippets
  6. iTextSharp快速使用指南
  7. asp.net mvc 多级目录结构
  8. [CareerCup] 17.11 Rand7 and Rand5 随机生成数字
  9. HDU 5437 Alisha’s Party (优先队列模拟)
  10. Sublime 2 Installation for Linux
  11. jquery中DOM的操作方法
  12. C#5.0新特性
  13. bzoj 4872: [Shoi2017]分手是祝愿 [期望DP]
  14. 关于vue的域名重定向和404
  15. OSM自建服务
  16. 【HDU5187】contest
  17. [math][mathematica] mathematica入门
  18. Spring Boot入门第三天:配置日志系统和Druid数据库连接池。
  19. doc转html
  20. ES6,新增数据结构Set的用法

热门文章

  1. html = data.decode(&#39;gbk&#39;).encode(&#39;utf-8&#39;)
  2. Python: 在Unicode和普通字符串之间转换
  3. python获取当前路径的方法
  4. 为了肾六(dp)
  5. 2014 北京邀请赛ABDHJ题解
  6. Erich Gamma
  7. 【Oracle】不安装Oracle客户端直接用PL/SQL连接数据库
  8. BZOJ 1263: [SCOI2006]整数划分( 高精度 )
  9. 3DShader之投影贴图(Projective Texturing)
  10. HDU 4617Weapon(两条异面直线的距离)