随手编程---快速排序(QuickSort)-Java实现
背景
快速排序,是在上世纪60年代,由美国人东尼·霍尔提出的一种排序方法。这种排序方式,在当时已经是非常快的一种排序了。因此在命名上,才将之称为“快速排序”。这个算法是二十世纪的七大算法之一,平均情况下时间复杂度为Ο(nlogn),而且在O(nlogn)的情况下,实际的运算速度都要快于其他同时间复杂度的排序方法。
对东尼·霍尔以及快速排序的提出背景感兴趣的同学,可以看看这篇介绍:http://www.nowamagic.net/librarys/veda/detail/2391
排序思想
快速排序的思路想到很困难,但是理解起来却非常容易
他的思路是这样的:
1、先选定队列中,某一个元素为基数Value(一般选择头元素,或尾元素)。
2、将基数Value依次与所有元素比较大小。按照比较结果将元素分为两个队列A、B。一个所有元素比基数Value大,一个所有元素比基数Value小。
3、将A作为新的队列,再次选定基数,然后分成两个更小的队列
4、就这样一直将每一个小的队列无限的拆分成更小的两个队列。
5、一直到一个队列已经拆分成不能拆封为止(也就是一个元素)
6、因为队列之间的顺序都是固定的。将这些队列一次组合起来,整体的排序就算完成了。
(防盗连接:本文首发自http://www.cnblogs.com/jilodream/ )
注意这里有两个最核心的步骤,就是
1、选出Value元素,将整体队列划分成两个子队列
2、然后将子队列重新作为一个新的,整体规模比当前要小的,新的队列,进行计算,直到计算起来非常容易为止。
这两个核心步骤造就了快排天生的优势:
1、通过比较大小划分到子队列中的元素,在未来的比较过程中,这个元素的比较范围始终都停留在这个子队列中,不再做多余的比较。这使得早期的比较对后期的比较仍然有很大的影响。而类似于冒泡的排序方法,则前期很多的比较,对后期的作用非常小。这点和kmp算法很像,前期的比较尽量做到最大的利用。
2、将原有规模的队列,拆分成若干个规模小的子队列,这些子队列要(防盗连接:本文首发自http://www.cnblogs.com/jilodream/ )解决的问题与原有队列一致,只是规模变小了。这样不断的拆分,形成一种分而治之的思想。这种思想与背包算法也是不谋而合。
对于文字理解起来有困难的同学,可以看下下边这张网上经典的动态图,非常生动:

下边是java实现的代码
import java.util.Arrays; public class QuickSort
{
public static void main(String args[])
{
QuickSort quicksort = new QuickSort();
int[] arrays = new int[]
{ 1, 12, 2, 13, 3, 14, 4, 15, 5, 16, 17, 17, 177, 18, 8, 8, 19 };
quicksort.quickSort(arrays);
System.out.println(Arrays.toString(arrays));
} private void quickSort(int[] arrays)
{
subQuickSort(arrays, 0, arrays.length - 1);
} private void subQuickSort(int[] arrays, int start, int end)
{
if (start >= end)
{
return;
}
int middleIndex = subQuickSortCore(arrays, start, end);
subQuickSort(arrays, start, middleIndex - 1);
subQuickSort(arrays, middleIndex + 1, end);
} private int subQuickSortCore(int[] arrays, int start, int end)
{
int middleValue = arrays[start];
while (start < end)
{
while (arrays[end] >= middleValue && start < end)
{
end--;
}
arrays[start] = arrays[end];
while (arrays[start] <= middleValue && start < end)
{
start++;
}
arrays[end] = arrays[start];
}
arrays[start] = middleValue;
return start;
}
}
随手编程---快速排序(QuickSort)-Java实现的更多相关文章
- 快速排序算法 java 实现
快速排序算法 java 实现 快速排序算法Java实现 白话经典算法系列之六 快速排序 快速搞定 各种排序算法的分析及java实现 算法概念 快速排序是C.R.A.Hoare于1962年提出的一种划分 ...
- 快速排序QuickSort
前几天实现了直接插入排序.冒泡排序和直接选择排序这三个基础排序.今天看了一下冒泡排序的改进算法,快速排序.单独记录一下,后面还有归并和基数排序等 快速排序 1.选择一个支点默认为数组第一个元素及arr ...
- 归并排序(MergeSort)和快速排序(QuickSort)的一些总结问题
归并排序(MergeSort)和快速排序(QuickSort)都是用了分治算法思想. 所谓分治算法,顾名思义,就是分而治之,就是将原问题分割成同等结构的子问题,之后将子问题逐一解决后,原问题也就得到了 ...
- 快速排序的Java和python实现,亲测实际可用
1.基本思想 快速排序每趟排序确定一个元素x的位置,使用的方式是 将大于元素x的值放大x的右边,小于元素x的值放大x的左边.当确定x的位置之后,再分别对x左边的数组和右边的数组进行快速排序即可. 2. ...
- 快速排序之Java实现
快速排序之Java实现 代码: package cn.com.zfc.lesson21.sort; /** * * @title QuickSort * @describe 快速排序 * @autho ...
- 排序算法四:快速排序(Quicksort)
快速排序(Quicksort),因其排序之快而得名,虽然Ta的平均时间复杂度也是O(nlgn),但是从后续仿真结果看,TA要比归并排序和堆排序都要快. 快速排序也用到了分治思想. (一)算法实现 pr ...
- 算法实例-C#-快速排序-QuickSort
算法实例 ##排序算法Sort## ### 快速排序QuickSort ### bing搜索结果 http://www.bing.com/knows/search?q=%E5%BF%AB%E9%80% ...
- 三、Android NDK编程预备之Java jni入门创建C/C++共享库
转自: http://www.eoeandroid.com/thread-264971-1-1.html 应网友回复,答应在两天前要出一篇创建C/C++共享库的,但由于清明节假期,跟朋友出去游玩,丢手 ...
- 二、Android NDK编程预备之Java jni入门Hello World
转自: http://www.eoeandroid.com/forum.php?mod=viewthread&tid=264543&fromuid=588695 昨天已经简要介绍了J ...
随机推荐
- tornado 学习笔记7 RequestHandler功能分析
在第5部分讲到,构建一个tornado网站,必须包含一个或者多个handler,这些handler是RequestHandler的子类.每个请求都会被映射到handler中进行处理,处理 ...
- linux install matlab2014a
https://pan.baidu.com/s/1qYJ9tNm#list/path=%2F下载镜像文件 2#开始安装,全程最好断网 sudo mkdir /media/matlab sudo mou ...
- WCF的同步和异步(以WPF连接为例)
2016-06-0711:05:44 在学习WCF时,学到WCF服务的同步和异步. 我理解的同步是: 当WCF服务是同步执行时,程序只有一条线程,代码只能按顺序一步一步来执行,当执行客户端/服务端某方 ...
- 【Alpha】Daily Scrum Meeting第六次
一.本次Daily Scrum Meeting主要内容 各队员的任务完成情况 接下去要做的任务有哪些方面的问题 二.项目进展 学号尾数 今日已完成任务 接下去要做 502 统一Excel表头数据的英文 ...
- nginx域名隐性(地址栏域名不变)跳转
1.完全url的域名隐性跳转 server_name a.b.com location / { proxy_pass http://x.y.com; } 效果:浏览器地址栏中输入a.b.com域名不变 ...
- PHP连接数据库的方法
mysql可通过两种方式通过PHP和web相连,一种通过php的mysql相关函数,另一种通过php的ODBC相关函数. 相关函数如下: MYSQL函数 mysql_affected_rows: 得到 ...
- CI框架入门1
CI框架入门: 1.url的特点 2.目录结构/布局 3.MVC分别在哪里,如何依葫芦画瓢 4.安全性 ...
- 读书笔记 —— 《css秘密花园》
浏览器兼容性有效性信息查询 : Can I Use? http://caniuse.com/ 自动为css添加浏览器厂商前缀 https://autoprefixer.github.io/ 在线编辑H ...
- 开源战棋 SLG 游戏框架设计思考(一)简介和游戏引擎
战棋 SLG 游戏 SLG(Simulation Game)游戏是模拟游戏的简称.战棋类的SLG有两种:一种是 War Game 中的兵棋推演分支,常见的游戏有战争艺术3(TOAW3 — The Op ...
- javaScript中其他类型的值转换为Boolean类型
将javaScript中其他任意类型的值转换为对应Boolean类型的值. 一 将number类型的值转换为Boolean类型 数值为0: var myBoolean = new Boolean(0 ...