JAVA数据结构--快速排序
快排概念
快速排序(英语:Quicksort),又称划分交换排序(partition-exchange sort),一种排序算法,最早由东尼·霍尔提出。在平均状况下,排序个项目要(大O符号)次比较。在最坏状况下则需要次比较,但这种状况并不常见。事实上,快速排序通常明显比其他算法更快,因为它的内部循环(inner loop)可以在大部分的架构上很有效率地被实现出来。
实现思想
快速排序使用分治法(Divide and conquer)策略来把一个序列(list)分为两个子序列(sub-lists)。
步骤为:
- 从数列中挑出一个元素,称为"基准"(pivot),
- 重新排序数列,所有比基准值小的元素摆放在基准前面,所有比基准值大的元素摆在基准后面(相同的数可以到任何一边)。在这个分区结束之后,该基准就处于数列的中间位置。这个称为分区(partition)操作。
- 递归地(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数据结构--快速排序的更多相关文章
- Java数据结构和算法(五)--希尔排序和快速排序
在前面复习了三个简单排序Java数据结构和算法(三)--三大排序--冒泡.选择.插入排序,属于算法的基础,但是效率是偏低的,所以现在 学习高级排序 插入排序存在的问题: 插入排序在逻辑把数据分为两部分 ...
- Java数据结构之树和二叉树(2)
从这里始将要继续进行Java数据结构的相关讲解,Are you ready?Let's go~~ Java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来 ...
- Java数据结构和算法(九)——高级排序
春晚好看吗?不存在的!!! 在Java数据结构和算法(三)——冒泡.选择.插入排序算法中我们介绍了三种简单的排序算法,它们的时间复杂度大O表示法都是O(N2),如果数据量少,我们还能忍受,但是数据量大 ...
- Java数据结构和算法 - 堆
堆的介绍 Q: 什么是堆? A: 这里的“堆”是指一种特殊的二叉树,不要和Java.C/C++等编程语言里的“堆”混淆,后者指的是程序员用new能得到的计算机内存的可用部分 A: 堆是有如下特点的二叉 ...
- Java数据结构和算法 - 高级排序
希尔排序 Q: 什么是希尔排序? A: 希尔排序因计算机科学家Donald L.Shell而得名,他在1959年发现了希尔排序算法. A: 希尔排序基于插入排序,但是增加了一个新的特性,大大地提高了插 ...
- Java数据结构与算法 - 外部存储
Q: 什么是外部存储? A: 外部存储特指某类磁盘系统,例如在大多数台式电脑或服务器中的硬盘. Q: 如何访问外部存储? A: 我们所学的数据结构都是假设数据存储在内存中,但是,在很多情况下要处理的数 ...
- Java数据结构和算法(五)二叉排序树(BST)
Java数据结构和算法(五)二叉排序树(BST) 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 二叉排序树(Binary S ...
- Java数据结构和算法(四)赫夫曼树
Java数据结构和算法(四)赫夫曼树 数据结构与算法目录(https://www.cnblogs.com/binarylei/p/10115867.html) 赫夫曼树又称为最优二叉树,赫夫曼树的一个 ...
- Java数据结构和算法(三)--三大排序--冒泡、选择、插入排序
三大排序在我们刚开始学习编程的时候就接触过,也是刚开始工作笔试会遇到的,后续也会学习希尔.快速排序,这里顺便复习一下 冒泡排序: 步骤: 1.从首位开始,比较首位和右边的索引 2.如果当前位置比右边的 ...
随机推荐
- 洛谷 P3627 [APIO2009](抢掠计划 缩点+spfa)
题目描述 Siruseri 城中的道路都是单向的.不同的道路由路口连接.按照法律的规定, 在每个路口都设立了一个 Siruseri 银行的 ATM 取款机.令人奇怪的是,Siruseri 的酒吧也都设 ...
- Photo2
Story: 驯鹿:“其实我只是想要一个肩膀而已.” 小男孩:“当你需要我的时候,我会在你身边.” Profession: 页面的主色调是淡黄色,这种柔和的色调表达出了柔和的气氛,整个画面颜色的运用都 ...
- matrix derivatives
来源:cs229 stanford Machine Learning Notes
- Hadoop权威指南文摘
第1章 初识Hadoop 1.1 数据!数据! 1.2 数据的存储与分析 HDFS实现数据的存储,MapReduce实现数据额分析与处理 1.3 相较于其他系统的优势 MapReduce是一个批量查询 ...
- Debug 时,执行语句
Display View The Display View displays the result of evaluating an expression in the context of the ...
- 在iOS中使用百度地图
就如同在百度地图的文档中所说的一样,这么来.但是,有一个小疏忽. 到添加完所需要的framework之后,一定要记得把你的(Class-Prefix)AppDelegate的后缀改成mm. 估计百度的 ...
- 编写高质量代码改善C#程序的157个建议——建议77: 正确停止线程
建议77: 正确停止线程 开发者总尝试对自己的代码有更多的控制.例如,“让那个还在工作的线程马上停止下来”.然而,并非我们想怎样就可以怎样的,这至少涉及两个问题. 第一个问题 正如线程不能立即启动一样 ...
- selenium爬取网易云
from selenium import webdriver from selenium.webdriver import ActionChains from selenium.webdriver.c ...
- Windows上编译Boost
Boost做得很好,有自己的build系统,可以几乎一键式编译,这才是尼玛世界一流质量的良心开源库啊. 将Boost 1.49.0解压到boost/boost_1_49_0里面,然后在boost目录底 ...
- mongodb driver2.5环境注意事项
mongodb driver2.5环境注意事项 一.问题: 如果使用vs2012开发就会报这个错误: 未能加载文件或程序集“System.Runtime.InteropServices.Runtime ...