快速排序
快速排序使用分治法策略来把一个序列分为两个子序列
算法步骤:
1. 从数列中挑出一个元素,称为 "基准"(pivot)
2. 重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面 (相同的数可以到任一边)。在这个分割结束之后,该基准就处于数列的中间位置。这个称为分割(partition)操作
3. 递归地(recursive)把小于基准值元素的子数列和大于基准值元素的子数列排序
* 比较复杂度:O(n㏒n)
* 交换(赋值)复杂度:O(n㏒n)
* 优点:比一般的排序都要快
public static void quickSort(Integer[] array) { if (array == null || array.length== 0) { return; } quickSort(array,0,array.length-1); }
private static void quickSort(Integer[] array, final int start, final int end){ //数组长度<=1退出 if(start>=end){ return; } //数组长度==2,比较两个元素的大小 if(end-start==1){ if(array[start]>array[end]){ swap(array,start,end); } return; } //用来进行比较的数 int compareNumber = array[start]; int middlePosition = 0; int i = start; int j = end; for(;;i++,j--){ //从数组首端开始迭代(不包括compareNumber),如果数组的数<compareNumber,不做移动 while(array[i]<compareNumber&&i<j){ i++; } //从数组尾端迭代,如果数组的数>=compareNumber,不做移动 while(array[j]>compareNumber&&i<j){ j--; } if(i>=j){ if(array[j]>compareNumber){ middlePosition = j; }else{ middlePosition = (j+1); } break; } //从数组首端开始迭代,得到大于compareNumber的数array[i],此时从尾端迭代直至得到<=compareNumber的数 //array[j],交换这两个数的位置,然后继续迭代 swap(array,i,j); } //递归排序 quickSort(array,start,middlePosition-1); quickSort(array,middlePosition,end); }
public static void swap(Object[] array,int a,int b){ Object temp = array[a]; array[a] = array[b]; array[b] = temp; }
作者:风过无痕-唐
出处:http://www.cnblogs.com/tangyanbo/
本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。 如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。欢迎加QQ讨论群
出处:http://www.cnblogs.com/tangyanbo/
本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。 如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。欢迎加QQ讨论群
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?