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

快速排序的基本思想:

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

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

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

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. Tomcat使用时出现的问题总结

    1.有两种办法解决Tomcat启动时端口号冲突问题 1.第一种: 查看本地端口使用情况,找到被占用的8080端口,杀死该进程 1.查看本地端口命令:cmd->netstat -ano 2.找到 ...

  2. 洛谷 P2467 地精部落 题解

    题面 好难啊好难啊好难啊~(以后再玩魔兽的时候绝对绝对虐死他) 做完后总结了一下思路; 首先推一下以下三条性质: 1.若两个 i 与 i+1 不相邻,那么我们直接交换这两个数字就可以组成一个新的数列 ...

  3. hibernate update-->参数绑定

    Hibernate 更新数据库 参数绑定总结: 一.query.setParameter(属性名,真实值,类型); String hql="update User u set u.userN ...

  4. Layui关闭弹出层并刷新父窗口

    先确保已经引入layui和jquery 再确保初始化layer弹出层 <script> layui.use(['form', 'layer'], function() { var form ...

  5. c语言小技巧:C语言学习笔记之位运算求余

    我们都知道,求一个数被另一个数整除的余数,可以用求余运算符”%“,但是,如果不 允许使用求余运算符,又该怎么办呢?下面介绍一种方法,是通过位运算来求余,但是注 意:该方法只对除数是2的N次方幂时才有效 ...

  6. 04: CI(持续集成)/CD(持续交付/持续部署)

    1.1 持续集成.持续交付 介绍   参考博客:https://www.cnblogs.com/cay83/p/8856231.html 1.传统交付 1. 传统软件的开发与交付的周期都很漫长,从需求 ...

  7. web部署命令简单记录

    非 root 用户设置环境变量:在< .bash_profile >中设置 后台运行:nohup dosomething >> log.out & nginx 启动ng ...

  8. MapReduce TopN(自主复习)

    1.MyTopN  主程序 package com.littlepage.topn; import org.apache.hadoop.conf.Configuration; import org.a ...

  9. LeNet-5模型的keras实现

    import keras from keras.models import Sequential from keras.layers import Input,Dense,Activation,Con ...

  10. 如何替换B字段内包含A字段的那部分内容

    Customer表A字段  varchar(50)     内容(客户姓名)B字段  varchar(1000)   内容(其他字符...客户姓名...其他字符)需要达到效果:将B字段中的客户姓名替换 ...