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

快速排序的基本思想:

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

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

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

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

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

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. 【五一qbxt】test2

    又犯了一些迷之错误??要不然yy鼠标就是我的了 1.Superman: 小姐姐的题解:直接用set模拟即可emmmm 里面有很多指针啊,乱七八糟的,不会qwq,先看看我的大模拟吧: #include& ...

  2. python之网络部分

    1.C/S B/S架构 C: client端 B: browse 浏览器 S: server端 C/S架构: 基于客户端与服务端之间的通信 ​ QQ, 游戏,皮皮虾, 快手,抖音. ​ 优点: 个性化 ...

  3. php文件上传php.ini配置参数

    php文件上传服务器端配置参数 file_uploads = On,支持HTTP上传uoload_tmp_dir = ,临时文件保存目录upload_max_filesize = 2M,允许上传文件的 ...

  4. 如何利用`keep-alive`按需缓存页面数据

    随着项目不断变大,页面变多,搜索条件也随之也越来越多,而每次跳转页面再返回时,之前的筛选的条件都会别清空.之前在elment-ui table组件 -- 远程筛选排序提到过缓存,但是有所取巧,这次重新 ...

  5. [.net core]7 4种app key value的配置方法及优先顺序

    就是这货 点开查看内容 { "Logging": { "LogLevel": { "Default": "Warning" ...

  6. FPGA开发时钟资源评估需要考虑的问题

    在第一个独立开发的FPGA项目中,使用了Altera平台的三速以太网IP,工作在100M模式下,外部输入的PHY时钟频率为25MHz. 由于在前期没有注意这个外部输入的时钟,导致最后不得不在板子上飞线 ...

  7. 【转】sysctl命令及改变net.ipv4.ip_forward = 1方法

    转自:https://blog.csdn.net/michaelzhou224/article/details/16979285 sysctl配置与显示在/proc/sys目录中的内核参数.可以用sy ...

  8. CodeForces - 841D Leha and another game about graph

    给出一个连通图,并给每个点赋一个d值0或1或-1,要求选出一个边的集合,使得所有的点i要么d[i] == -1,要么 dgree[i] % 2 == d[i],dgree[i]代表i结点的度数. 考虑 ...

  9. 前端每日实战:158# 视频演示如何用纯 CSS 创作一个雨伞 toggle 控件

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/pxLbjv 可交互视频 此视频是可 ...

  10. throttle和debounce函数

    控制耗性能的函数,避免浏览器卡死