快速排序是对冒泡排序的一种改进。

快速排序的基本思想:

假设我们以升序为例,它的执行流程可以概括为,每一趟选择当前所有子序列中的一个关键字(通常我们选择第一个,下述代码实现选择的也是第一个数)作为枢纽,将子序列中比枢纽小的移动到枢纽前面,比枢纽大的移动到枢纽的后边;当本趟所有子序列都被枢纽以上述规则划分完毕后会得到新的 一组更短的子序列,我们将这个子序列作为下一趟划分的初始序列集。

快速排序的图解表示:(该图片是网上找的,下面的代码也是基于这个思想写的)

快速排序的代码如下:(快速排序的集体讲解会在代码的注释中说明)

  1. public static void main(String[] args) {
  2. // TODO Auto-generated method stub
  3.  
  4. int[] arr = {-9,78,0,23,-567,70};
  5. quickSort(arr, 0, arr.length-1);
  6. System.out.println(Arrays.toString(arr));
  7. }
  8. //我们默认的是以每趟序列的第一个数为基准
  9. public static void quickSort(int[] arr,int left,int right){
  10. int temp = 0; //基准
  11. int l = left; //最左边的元素
  12. int r = right; //最右边的元素
  13. if(left<right){
  14. //我们将这个数组中的第一个数赋值给temp。
  15. temp = arr[left]; //temp想当于我们的基准,数列的第一个数
  16. while(l!=r){ //我们假定,当l=r的时候退出该循环
  17. //开始的时候,我们从最右边开始找元素,当我们找的元素的值大于等于我们的基准,那么我们将它向左移,直到这个元素的值小于基准为止。
  18. while(r>l && arr[r]>=temp){
  19. --r;
  20. }
  21. //此时arr[r]已经小于temp,这个时候我们需要进行一个判断,看看是否还是符合l<r,如果符合的话,我们将arr[r]这个值,直接赋值到左边(数组的第一个值)
  22. //并且让我们左边的l指向下一个位置。
  23. if(l<r){
  24. arr[l] = arr[r];
  25. ++l;
  26. }
  27. //在右边换过来之后,我们需要交叉得变换,这个时候我们从左边开始比较
  28. //前提还是l<r,只不过由于我们在左边开始,所以我们需要判断arr[l]如果小于temp的值,那么我们应该继续向右移,以知道大于等于temp的值为止。
  29. while(l<r && arr[l]<temp){
  30. ++l;
  31. }
  32. //此时arr[r]已经大于或者等于temp,这个时候我们需要进行一个判断,看看是否还是符合l<r,如果符合的话,我们将arr[r]这个值,直接赋值到右边(r所在的位置)
  33. //并且让我们右边的r指向下一个位置。
  34. if(l<r){
  35. arr[r] = arr[l];
  36. --r;
  37. }
  38. }
  39. //在执行完上面的循环之后,我们除了基准的位置的空的外,基准左边的都小于它,基准右边的都大于它,形成了一个相对有序的序列,
  40. //最终我们把之前赋值的temp加入到arr[l]中(因为这个时候r=l)
  41. arr[l] = temp;
  42. //执行完上面的依次循环之后,我们需要对子序列进行在依次的快速排序,执行过程与上面的相同。
  43. quickSort(arr, left, l-1);
  44. quickSort(arr, l+1, right);
  45. }
  46. }

  上述代码得到的最终结果如下:

Java数据结构之排序---快速排序的更多相关文章

  1. Java数据结构与排序

    一.引子:想要给ArrayList排序却发现没有排序方法?你有两种选择:        1.换用TreeSet:     2.使用Collection.sort(List<T> list) ...

  2. JAVA数据结构--希尔排序

    希尔排序通过将比较的全部元素分为几个区域来提升插入排序的性能.这样可以让一个元素可以一次性地朝最终位置前进一大步.然后算法再取越来越小的步长进行排序,算法的最后一步就是普通的插入排序,但是到了这步,需 ...

  3. JAVA数据结构--选择排序

    选择排序(Selection sort)是一种简单直观的排序算法.它的工作原理如下.首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然 ...

  4. Java数据结构之排序

    1.冒泡排序:时间复杂度为O(n2) 假设是由小到大排序:相邻两个数之间进行比较,较大的数在后面.一次比较过后最大的数排在最后面 如:40.8.15.18.12一次排序后为:8.15.18.12.40 ...

  5. Java数据结构(排序篇)

    冒泡排序:是经过n-1趟子排序完毕的,第i趟子排序从第1个数至第n-i个数,若第i个数比后一个数大(则升序,小则降序)则交换两数.大泡在上,小泡在下. 选择排序:每一趟从待排序的数据元素中选出最小(或 ...

  6. Java数据结构之排序---希尔排序

    希尔排序的基本介绍: 希尔排序同之前的插入排序一样,它也是一种插入排序,只不过它是简单插入排序之后的一个优化的排序算法,希尔排序也被称为缩小增量排序. 希尔排序的基本思想: 希尔排序是把数组中给定的元 ...

  7. Java数据结构之排序---插入排序

    插入排序的基本介绍: 插入排序是对想要排序的序列以插入的方式寻找该元素的适当的位置,从而达到排序的目的. 插入排序的基本思想: 把n个待排序的元素看成一个有序表和一个无序表,开始时,有序表只有一个元素 ...

  8. Java数据结构之排序---选择排序

    简单选择排序的介绍: 从给定的序列中,按照指定的规则选出某一个元素,再根据规定交换位置后达到有序的目的. 简单选择排序的基本思想: 假定我们的数组为int [] arr = new int[n],第一 ...

  9. Java数据结构之排序---冒泡排序

    冒泡排序的基本思想: 通过对待排序序列从前到后(从下标小的元素开始),依次比较相邻位置的元素的值,若发现与给定的次序冲突,则交换位置(假设数值大的数放在序列的后面),使数值较大的元素逐渐从前移动到后部 ...

随机推荐

  1. SpringBoot_01

    一.初识springboot 个人总结:springboot是一个开发更加便捷的spring的技术框架,通过引入启动器便可以快捷的让spring框架和其他框架进行整合, springboot很容易上手 ...

  2. Radio Button误区

    在同一个父容器下,Radio Button控件默认只能选择一个,所以无需多余代码管控 如果将Radio Button的多个子对象存入NSArray列表,发现长度为0(巨坑),因此通过列表对其初始化不可 ...

  3. [TJOI2019] 甲苯先生的线段树

    臭名昭著的巧合:CF750G 题意:在无限深度的一颗线段树中询问编号和为S的简单路径条数. 题解传送门 这道题相当于在原来基础上多了询问两点间简单路径的编号的的问题. 直觉告诉我们只需要求出两点在线段 ...

  4. linux命令 集合

    ps:查看所有进程 // -e :显示所有进程:-f:代表全格式 ps -ef | grep python :查看后台运行的python程序,| 表示管道,grep表示筛选 & 符号:后台执行 ...

  5. PythonError解决方案

    # Pip Error pip install * error: Microsoft Visual C++ 14.0 is required. Get it with “Microsoft Visua ...

  6. vue项目中引入循环执行setInterval或者requestAnimationFrame的用法等

    项目中循环计时处理某些方法的情况还是比较常见的,一般会用setInterval来处理,但是这个方法会似的页面卡顿等使用体验不好. 所以就使用浏览器提供的requestAnimationFrame方法, ...

  7. 04.AutoMapper 之投影(Projection)

    https://www.jianshu.com/p/031553705417 投影(Projection) 投影将源转换为目标而不是扁平化对象模型.如果没有额为的配置AutoMapper需要一个扁平化 ...

  8. Git命令的总结

    Git 是当前最流行的版本控制程序之一,文本包含了 Git 的一些基本用法 创建 git 仓库 初始化 git 仓库 mkdir project  # 创建项目目录cd project  # 进入到项 ...

  9. 初探 -5 JavaScript 语法

    JavaScript 是一个程序语言.语法规则定义了语言结构. JavaScript 语法 JavaScript 是一个脚本语言. 它是一个轻量级,但功能强大的编程语言. JavaScript 字面量 ...

  10. MyCAT与MySQL导入、导出文件

    1. MySQL批量导入-LOAD DATA使用本地客户端连接MySQL数据库,批量导入数据,出现报错:2017-06-07 09:30:45,936 MySqlWrapper::ImportCSVt ...