java 实现 常见排序算法(三)快速排序

大家好,我是烤鸭:    

   今天分享一下基础排序算法之快速排序。快速排序是内部排序(基于比较排序)中最好的比较算法。

 

1.     快速排序:


原理:在要排的数(比如数组A)中选择一个中心值key(比如A[0]),通过一趟排序将数组A分成两部分,其中以key为中心,key右边都比key大,key左边的都key小,然后对这两部分分别重复这个过程,直到整个有序。
        整个快排的过程就简化为了一趟排序的过程,然后递归调用就行了。

思路:

1,定义i=0,j=A.lenght-1,i为第一个数的下标,j为最后一个数下标
2,从数组的最后一个数Aj从右往左找,找到第一小于key的数,记为Aj;
3,从数组的第一个数Ai 从左往右找,找到第一个大于key的数,记为Ai;
4,交换Ai 和Aj 
5,重复这个过程,直到 i=j
6,调整key的位置,把A[i] 和key交换

  例如  6 9 8 5 4 7(i=0,j=0)first time: 4 9 8 5 6 7  从左向右,取>=6的(第一个为6),从右向左,取比6小的(第一个为4),交换位置(i=0,j=1)second time: 4 5 8 9 6 7 比6大的第二个元素9,比6小的第二个元素5,交换位置(i=1,j=2)third time: 4 5 8 9 6 7 再继续i > j了,递归原方法,45基准变成4,8967基准变成8(i=2,j=1)forth time: 4 5 7 9 6 8  同上,8和7交换(i=2,j=5)fifth time: 4 5 7 6 9 8  同上,9和6交换(i=3,j=4)再同上 , 7和6交换。9和8交换。

代码实现:

public void quickSort(int[] numbers, int start, int end) {if (start < end) {int base = numbers[start];         // 选定的基准值(第一个数值作为基准值)int temp;                          // 记录临时中间值int i = start, j = end;do {while ((numbers[i] < base) && (i < end)) {i++;}while ((numbers[j] > base) && (j > start)) {j--;}if (i <= j) {temp = numbers[i];numbers[i] = numbers[j];numbers[j] = temp;i++;j--;}} while (i <= j);if (start < j) {quickSort(numbers, start, j);}if (end > i) {quickSort(numbers, i, end);}}}

耗时对比:

10W 条随机 数据 运行如图:

分别对比了冒泡排序,直插排序,希尔排序和快速排序。差距很明显。

50W 条随机 数据 运行如图:

分别对比了冒泡排序,直插排序,希尔排序和快速排序。差距很明显。

100W 条随机 数据 运行如图:

分别对比了冒泡排序,直插排序,希尔排序和快速排序。差距很明显。

总结:

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

最坏时间复杂度和插入排序相同:O(n^2)。

冒泡排序总的平均时间复杂度为:O(nlog2n) 。

各种排序方法比较:

 

更多排序算法:

冒泡排序   :  https://blog.csdn.net/Angry_Mills/article/details/81057900

插入排序   :  https://blog.csdn.net/Angry_Mills/article/details/81208700

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/412870.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[css] 请问background-attachmentn属性有什么用途?

[css] 请问background-attachmentn属性有什么用途&#xff1f; background-attachment: fixed / scroll / local&#xff1a; 设置背景图像是否固定或者随着页面的其余部分滚动。fixed: 背景图片不会随着页面的滚动而滚动。scroll: 背景图片随着页面的滚动而滚动&#xff0c;这…

解决org.apache.hadoop.io.nativeio.NativeIOException: 当文件已存在时,无法创建该文件。

Hadoop在本地运行的时候总是出现这个异常&#xff0c;虽然这个异常不影响代码运行&#xff0c;但是看着很不爽 1&#xff0c;找到log4j.properties文件&#xff0c;查看log4j.rootLogger&#xff0c;但是却没有debug log4j.rootLogger info,stdout2&#xff0c;查看pom.xm…

两台TP-LINK路由器串联

TP-LINK的交换机LAN口连接电脑&#xff0c;设置交换机IP为192.168.2.1&#xff0c;为以后方便管理不设置自动获取IP地址&#xff0c;不设置DHCPLAN口连接路由器网线&#xff0c;不是WAN口其他电脑也连接LAN口&#xff0c;即可上网 https://www.192ly.com/qiu-zhu/two-routers-c…

[css] 移动页面底部工具条有3个图标,如何平分?在设置边框后最后一个图标掉下去了怎么办?

[css] 移动页面底部工具条有3个图标&#xff0c;如何平分&#xff1f;在设置边框后最后一个图标掉下去了怎么办&#xff1f; flex-wrap nowrap, 一般flex默认就是nowrap white-space:nowrap是针对行内元素设置的,默认为normal个人简介 我是歌谣&#xff0c;欢迎和大家一起交流…

springboot websocket

大家好&#xff0c;我是烤鸭&#xff1a; 今天想分享一下springbootwebsocket。 之前接到一个需求&#xff0c;需要在页面监听后台的数据&#xff08;输入邮箱后&#xff0c;需要用户打开邮箱&#xff0c;页面监听用户是否点击激活邮件&#xff09;。之前的实现方式&#xff0c…

[网络开发]同步与线程安全方案

方案&#xff1a;synchronized,volatileCAS&#xff08;compareAndSet&#xff09;,atomic包&#xff0c;Lock接口 java同步和IO同步的对比&#xff1a; 都是同步异步的方案问题&#xff0c;一个操作的是java代码(实际是堆和方法区)&#xff0c;一个操作的是TCP RecvBuffer而已…

[css] 说下你对background-size的理解,它有什么运用场景?

[css] 说下你对background-size的理解&#xff0c;它有什么运用场景&#xff1f; 设置背景图的大小&#xff0c;一般用来设置背景图的大小。个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 …

idea的plugins无法使用marketplace plugins are not loaded

idea64.exe.vmoptions删除-Djsse.enableSNIExtensionfalse 再次重启后就可以正常使用plugins&#xff01;&#xff01;&#xff01;

redis实践的一点思路,关于支付回调

大家好&#xff0c;我是烤鸭: 如果作为第三方支付平台&#xff0c;需要通知调用方付款成功。但是出现通知失败的情况&#xff0c;怎么处理。 支付宝的异步通知&#xff0c;每个订单的异步通知实行分频率发送:15s 3m 10m 30m 30m 1h 2h 6h 15h。 如果没有收到success&a…

断电启动+智能插座 七彩虹B460主板实现电脑远程开机

BIOS设置操作步骤&#xff1a; 1&#xff0c;开机按F2进入BIOS系统&#xff08;小提示&#xff1a;不同的主板按键不一样&#xff0c;开机应该有提示&#xff09; 2&#xff0c;高级模式 > 高级 > 电源管理设置 > 交流电源恢复后处理 > 选择“开机” 3&#xff0c…

[css] 如何自定义radio按钮的样式

[css] 如何自定义radio按钮的样式 选择器 input[type“radio”]现在几乎不用原生的radio&#xff0c;一是原生样式改成设计稿的样子太浪费时间&#xff0c;二是不同浏览器对于原生radio的展示还不一样。基于状态驱动的思想&#xff0c;用自定义按钮或其他元素来替代radio&…

myabtis 数字+逗号 传参问题 $和#

大家好&#xff0c;我是烤鸭&#xff1a; 遇到一个maybatis传参的问题。 如果传参是数字逗号的形式&#xff0c;比如1,2,3,4,5。 问题复现&#xff1a; 项目中查询sql和navicat查询sql结果不一致。 1 项目中&#xff1a; 如图所示&#xff0c;查到一条数据。 可以看到…

SpringBoot上传文件到本服务器 目录与jar包同级

前言 看标题好像很简单的样子&#xff0c;但是针对使用jar包发布SpringBoot项目就不一样了。 当你使用tomcat发布项目的时候&#xff0c;上传文件存放会变得非常简单&#xff0c;因为你可以随意操作项目路径下的资源。但是当你使用SpringBoot的jar包发布项目的时候&#xff0c;…

JS判断是否是科学计算结果并处理

var re 505899.24- 495991.61- 9907.63;var test1 /\d(?:.(\d*))?e([-]\d)/.test(re);alert("是否是科学计算结果:"test1);var test2 re.toFixed(10)-0;alert("处理后的结果&#xff1a;" test2 );

[css] css怎样使每个字符宽度一样?

[css] css怎样使每个字符宽度一样&#xff1f; 控制字符间距&#xff1a;letter-spacing:1em;[em,px,rem]个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

org.apache.catalina.connector.ClientAbortException: java.io.IOException: Broken pipe

大家好&#xff0c;我是烤鸭&#xff1a; 又是采坑实录。 异常如下&#xff1a; org.apache.catalina.connector.ClientAbortException: java.io.IOException: Broken pipeat org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:356)at org.ap…

[css] word-wrap、word-break和white-space有什么区别?

[css] word-wrap、word-break和white-space有什么区别&#xff1f; word-wrap标明是否允许浏览器再单词内进行断句normal 只允许在断字点换行 默认值break-word 在长单词或这url地址内部进行换行word-break标明怎么样进行单词内的断句normal 默认值break-all 允许在单词内换行k…

Redis免费客户端 Another Redis DeskTop Manager 下载地址及安装教程

下载及安装教程地址&#xff1a;GitHub - qishibo/AnotherRedisDesktopManager: &#x1f680;&#x1f680;&#x1f680;A faster, better and more stable redis desktop manager [GUI client], compatible with Linux, Windows, Mac. Whats more, it wont crash when loadi…

[css] 说说你对字母“X“在CSS中有什么作用?

[css] 说说你对字母"X"在CSS中有什么作用&#xff1f; 可以用作关闭按钮叉叉X的底部与文本对齐的基线位置相同个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面…

JavaScript文字转图片

非常感谢这位博主提供的代码&#xff0c;以下只做代码记录 博文转载地址&#xff1a;https://blog.csdn.net/qq_30100043/article/details/76549377//绘制文字到canvas&#xff0c;判断换行位置&#xff0c;和设置canvas高度 function canvasWrapText(options) {var settings …