快排概念

快速排序(英语:Quicksort),又称划分交换排序(partition-exchange sort),一种排序算法,最早由东尼·霍尔提出。在平均状况下,排序个项目要(大O符号)次比较。在最坏状况下则需要次比较,但这种状况并不常见。事实上,快速排序通常明显比其他算法更快,因为它的内部循环(inner loop)可以在大部分的架构上很有效率地被实现出来。

实现思想

快速排序使用分治法(Divide and conquer)策略来把一个序列(list)分为两个子序列(sub-lists)。

步骤为:

  1. 从数列中挑出一个元素,称为"基准"(pivot),
  2. 重新排序数列,所有比基准值小的元素摆放在基准前面,所有比基准值大的元素摆在基准后面(相同的数可以到任何一边)。在这个分区结束之后,该基准就处于数列的中间位置。这个称为分区(partition)操作。
  3. 递归地(recursively)把小于基准值元素的子数列和大于基准值元素的子数列排序。

递归到最底部时,数列的大小是零或一,也就是已经排序好了。这个算法一定会结束,因为在每次的迭代(iteration)中,它至少会把一个元素摆到它最后的位置去。

借用下啊哈算法的图:

i和j分别为左哨兵和右哨兵,这里枢纽元定为6,然后分别从左往右(i++)和右往左(j--)开始遍历

左哨兵查找比6大的元素,右哨兵查找比6小的元素

第一次交换结果

第二次交换结果

相遇后直接与枢纽元交换

然后再递归排序就行


快排核心算法代码

 public static <T extends Comparable<? super T>> void quicksort(T[] a,int left,int right) {
/*
* 当数组不小于3时,才推荐使用快排
* */
if(left+CUTOFF<=right)
{
//取出枢纽元,枢纽元的位置为right-1
T privot=median3(a, left, right); int i=left,j=right-1;
for(;;)
{
while(a[++i].compareTo(privot)<0) {}//i哨兵向右遍历
while(a[--j].compareTo(privot)>0) {}//j哨兵向左遍历
if(i<j)
swapReferences(a, i, j);
else
break;
}
/*
* for循环终止条件为i和j相遇,此时再将枢纽元归位
* */
swapReferences(a, i, right-1); quicksort(a, left, i-1);//对左半部进行递归
quicksort(a, i+1, right);//对右半部进行递归
}
else
{}
}

全部代码实现

 public class MyQuickSort {
private static final int CUTOFF=3;
public static <T extends Comparable<? super T>> void quicksort(T[] a) {
quicksort(a,0,a.length-1);
}
public static <T extends Comparable<? super T>> void quicksort(T[] a,int left,int right) {
/*
* 当数组不小于3时,才推荐使用快排
* */
if(left+CUTOFF<=right)
{
//取出枢纽元,枢纽元的位置为right-1
T privot=median3(a, left, right); int i=left,j=right-1;
for(;;)
{
while(a[++i].compareTo(privot)<0) {}//i哨兵向右遍历
while(a[--j].compareTo(privot)>0) {}//j哨兵向左遍历
if(i<j)
swapReferences(a, i, j);
else
break;
}
/*
* for循环终止条件为i和j相遇,此时再将枢纽元归位
* */
swapReferences(a, i, right-1); quicksort(a, left, i-1);//对左半部进行递归
quicksort(a, i+1, right);//对右半部进行递归
}
else
{}
}
/*
* 数组中数值交换
* */
public static <T> void swapReferences(T[] a,int index1,int index2) {
T tmp=a[index1];
a[index1]=a[index2];
a[index2]=tmp;
}
/*
* 确定枢纽元,枢纽元的位置放在right-1位置
* */
private static <T extends Comparable<? super T>> T median3(T[] a,int left,int right) {
int center=(left+right)/2;
if(a[center].compareTo(a[left])<0)
swapReferences(a, left, center);
if(a[right].compareTo(a[center])<0)
swapReferences(a, center, right);
if(a[right].compareTo(a[left])<0)
swapReferences(a, left, right); swapReferences(a, center, right-1);
return a[right-1];
}
}

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

  1. Java数据结构和算法(五)--希尔排序和快速排序

    在前面复习了三个简单排序Java数据结构和算法(三)--三大排序--冒泡.选择.插入排序,属于算法的基础,但是效率是偏低的,所以现在 学习高级排序 插入排序存在的问题: 插入排序在逻辑把数据分为两部分 ...

  2. Java数据结构之树和二叉树(2)

    从这里始将要继续进行Java数据结构的相关讲解,Are you ready?Let's go~~ Java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来 ...

  3. Java数据结构和算法(九)——高级排序

    春晚好看吗?不存在的!!! 在Java数据结构和算法(三)——冒泡.选择.插入排序算法中我们介绍了三种简单的排序算法,它们的时间复杂度大O表示法都是O(N2),如果数据量少,我们还能忍受,但是数据量大 ...

  4. Java数据结构和算法 - 堆

    堆的介绍 Q: 什么是堆? A: 这里的“堆”是指一种特殊的二叉树,不要和Java.C/C++等编程语言里的“堆”混淆,后者指的是程序员用new能得到的计算机内存的可用部分 A: 堆是有如下特点的二叉 ...

  5. Java数据结构和算法 - 高级排序

    希尔排序 Q: 什么是希尔排序? A: 希尔排序因计算机科学家Donald L.Shell而得名,他在1959年发现了希尔排序算法. A: 希尔排序基于插入排序,但是增加了一个新的特性,大大地提高了插 ...

  6. Java数据结构与算法 - 外部存储

    Q: 什么是外部存储? A: 外部存储特指某类磁盘系统,例如在大多数台式电脑或服务器中的硬盘. Q: 如何访问外部存储? A: 我们所学的数据结构都是假设数据存储在内存中,但是,在很多情况下要处理的数 ...

  7. Java数据结构和算法(五)二叉排序树(BST)

    Java数据结构和算法(五)二叉排序树(BST) 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 二叉排序树(Binary S ...

  8. Java数据结构和算法(四)赫夫曼树

    Java数据结构和算法(四)赫夫曼树 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 赫夫曼树又称为最优二叉树,赫夫曼树的一个 ...

  9. Java数据结构和算法(三)--三大排序--冒泡、选择、插入排序

    三大排序在我们刚开始学习编程的时候就接触过,也是刚开始工作笔试会遇到的,后续也会学习希尔.快速排序,这里顺便复习一下 冒泡排序: 步骤: 1.从首位开始,比较首位和右边的索引 2.如果当前位置比右边的 ...

随机推荐

  1. CF 662C Binary Table

    用FWT优化计算. 首先发现行数很小,想到一个暴力的方法,就是以一个二进制位$0$表示这一行不翻转而二进制位$1$表示这一行翻转,然后$2^n$枚举出所有行的翻转情况,再$O(m)$计算所有的结果. ...

  2. xml与java代码相互装换的工具类

    这是一个java操作xml文件的工具类,最大的亮点在于能够通过工具类直接生成xml同样层次结构的java代码,也就是说,只要你定义好了xml的模板,就能一键生成java代码.省下了自己再使用工具类写代 ...

  3. [GO]结构体的值传递和地址传递

    package main import "fmt" type student struct { id int name string sex byte age int addr s ...

  4. Python3+Apache+Django+CentOS

    使用django开发的项目上到正式环境的环境搭建,系统软件版本: CentOS6. setuptools-.tar.gz pip-.tar.gz Python-.tgz pcre-8.39.tar.b ...

  5. DFS实现全排列

    复习一下DFS实现全排列,具体思想见:https://www.cnblogs.com/chiweiming/p/9279858.html public class Main{ static int a ...

  6. 【C#】泛型

    泛型是一个非常有用的技术,在博客园里面有太多说到泛型的好文章,这里我推荐一篇我个人觉得非常全面,也非常齐全的文章. (重造轮子很傻!!!) C# -- 泛型(1) C# -- 泛型(2) C# -- ...

  7. mysql连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

    现象:客户端连接服务器端mysql是没问题的,所有都木有问题,应用程序配置也没问题,但是连接就抛异常: com.mysql.jdbc.exceptions.jdbc4.CommunicationsEx ...

  8. elasticsearch(0.90.10)安装配置+超多插件!!

    一)安装elasticsearch 1)下载elasticsearch-0.90.10,解压,运行\bin\elasticsearch.bat (windwos) 2)进入http://localho ...

  9. html中的table导出Excel

    演示地址: http://www.jq22.com/yanshi3312 具体代码: <!DOCTYPE html> <html lang="zh-CN"> ...

  10. Charles弱网测试

    当前APP网络环境比较复杂,网络制式有2G.3G.4G网络,还有越来越多的公共Wi-Fi.不同的网络环境和网络制式的差异,都会对用户使用app造成一定影响.另外,当前app使用场景多变,如进地铁.上公 ...