排序算法-快速排序(Java)
package com.rao.sort; import java.util.Arrays; /**
* @author Srao
* @className QuickSort
* @date 2019/12/9 14:13
* @package com.rao.sort
* @Description
*/
public class QuickSort { /**
* 把数组从中间分开,左边的数都小于pivot,右边的数都大于pivot
* @param arr:要拆分的数组
* @param left:从left开始计算
* @param right:到right截至
* @return 返回中间值的下标
*/
public static int partition(int[] arr, int left, int right){
//把数组中的第一个数当作pivot
int pivot = arr[left];
//左指针指向pivot右边的第一个数
int i = left+;
//指向数组末尾最后一个数
int j = right;
while (true){
//从左边开始,找到第一个比pivot大的数
while (i <= j && arr[i] <= pivot){
i++;
}
//从右边开始,找到第一个比pivot小的数
while (i <= j && arr[j] >= pivot){
j--;
}
if (i >= j){
break;
}
//交换上面两个数
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
//把pivot交换到数组中间,此时数组大致有序,以pivot为界限,左边的数都比pivot小,右边的数都比pivot大
arr[left] = arr[j];
arr[j] = pivot;
return j;
} /**
* 快速排序
* @param arr
* @param left
* @param right
*/
public static void quickSort(int[] arr, int left, int right){
//用来保存pivot的下标
int center;
if (left < right){
center = partition(arr, left, right);
quickSort(arr, left, center-);
quickSort(arr, center+, right);
}
} public static void main(String[] args) {
int[] arr = {, , , , };
System.out.println(Arrays.toString(arr));
quickSort(arr, , arr.length-);
System.out.println(Arrays.toString(arr)); }
}
快速排序和归并排序都是采用分治的思想,对数组进行拆分排序,但是快速排序再开辟一个新的数组保存数据,比归并排序节省空间,两个排序的平均时间复杂度都为O(nlogn)
排序算法-快速排序(Java)的更多相关文章
- 基本排序算法——快速排序java实现
简单的快速排序算法,我竟然花费了如此多的时间来写作,好好学习. /** * */ package basic.sort; import java.util.Arrays; import java.ut ...
- 排序算法----快速排序java
快速排序是对冒泡排序的一种改进,平均时间复杂度是O(nlogn) import java.util.Arrays; import java.util.Scanner; public class tes ...
- 《Java算法》排序算法-快速排序
排序算法-快速排序: /** * 给定一个数组:按照从小到大排序. * 思路: * 1. 获取第一个数放入临时变量data,将大于data的数放右边,小于data的数放在左边. * 2. data左边 ...
- 常见排序算法(附java代码)
常见排序算法与java实现 一.选择排序(SelectSort) 基本原理:对于给定的一组记录,经过第一轮比较后得到最小的记录,然后将该记录与第一个记录的位置进行交换:接着对不包括第一个记录以外的其他 ...
- 几大排序算法的Java实现
很多的面试题都问到了排序算法,中间的算法和思想比较重要,这边我选择了5种常用排序算法并用Java进行了实现.自己写一个模板已防以后面试用到.大家可以看过算法之后,自己去实现一下. 1.冒泡排序:大数向 ...
- 7种基本排序算法的Java实现
7种基本排序算法的Java实现 转自我的Github 以下为7种基本排序算法的Java实现,以及复杂度和稳定性的相关信息. 以下为代码片段,完整的代码见Sort.java 插入排序 /** * 直接插 ...
- 几种简单的排序算法(JAVA)
几种排序算法(JAVA) 一.代码 package com.hdwang; import java.util.Arrays; /** * Created by admin on 2017/1/20. ...
- 常见排序算法总结 -- java实现
常见排序算法总结 -- java实现 排序算法可以分为两大类: 非线性时间比较类排序:通过比较来决定元素间的相对次序,由于其时间复杂度不能突破O(nlogn),因此称为非线性时间比较类排序. 线性时间 ...
- 几大排序算法的Java实现(原创)
几大排序算法的Java实现 更新中... 注: 该类中附有随机生成[min, max)范围不重复整数的方法,如果各位看官对此方法有什么更好的建议,欢迎提出交流. 各个算法的思路都写在该类的注释中了,同 ...
- 数据结构和算法(Golang实现)(25)排序算法-快速排序
快速排序 快速排序是一种分治策略的排序算法,是由英国计算机科学家Tony Hoare发明的, 该算法被发布在1961年的Communications of the ACM 国际计算机学会月刊. 注:A ...
随机推荐
- 第17课 lambda表达式
一. lambda表达式 (一)语法定义:[capture](paramters) mutable ->returnType{statement} 1.[capture]:捕获列表 (1)lam ...
- SpringBoot之CommandLineRunner接口和ApplicationRunner接口
我们在开发中可能会有这样的情景.需要在容器启动的时候执行一些内容.比如读取配置文件,数据库连接之类的.SpringBoot给我们提供了两个接口来帮助我们实现这种需求.这两个接口分别为CommandLi ...
- docker命令集合
#docker安装yum -y install docker-iodocker --version #启动Docker进程systemctl start dockersystemctl status ...
- 使用velero进行kubernetes灾备
使用velero可以对集群进行备份和恢复,降低集群DR造成的影响.velero的基本原理就是将集群的数据备份到对象存储中,在恢复的时候将数据从对象存储中拉取下来.可以从官方文档查看可接收的对象存储,本 ...
- 奥展项目笔记01--不同网站,点击工具--开发人员工具F12,显示的页面怎么不一样
开发人员工具F12,显示的页面不一样: 样式1: 样式2: 解决方案:兼容模式和极速模式的开发者工具不一样,改成极速模式就ok了.
- IScroll Unable to preventDefault inside passive event listener due to target being treated as passive
最近两天企业微信下IScroll突然无法滚动了,特别慢,之前好好的,发现主要是有红色的Unable to preventDefault inside passive event listener du ...
- golang---常用函数
package main; import ( "os" "fmt" "time" "strings" ) //os包中的 ...
- .Net FrameWork获取配置文件信息
今天在做项目的时候需要到配置文件中读取信息,之前自己并没有操作过,今天算是完成自己的一个心愿.读取配置文件中的信息并不难,大致思路是: 1.载入配置文件,获取配置文件的实例. 2.获取配置文件的节点 ...
- Linq与委托
using System; using System.Linq; using System.Reflection; using Stuglxt_Models; namespace ConsoleApp ...
- C#安全类型转换基于convert
using Newtonsoft.Json; using System; using System.Collections.Generic; using System.Globalization; n ...