数据结构-八大排序之快速排序

快速排序(quick sort)

一、思路

快速排序是C.R.A.Hoare于1962年提出的一种划分交换排序。它采用了一种分治的策略,通常称其为分治法(Divide-and-ConquerMethod)。

该方法的基本思想是:

  • 1.先从数列中取出一个数作为基准数。
  • 2.分区过程,将比这个数大的数全放到它的右边,小于或等于它的数全放到它的左边。
  • 3.再对左右区间重复第二步,直到各区间只有一个数。

二、例子

步骤:

1.定义待排序数组当中的第一个值作为基准数(base)

2.定义 j 游标,从后往前移动找到第一个比基准数小的值停下

  1. 定义i 游标,从前往后移动找到第一个比基准数大的值停下。

  2. i和j数值交换

  1. 重复2-4直到 i和j 相遇

  2. 基准数和相遇位置的数据进行交换,交换完成之后基准数到达正确位置。

  1. 以基准数为起始点,分成左右两部分,重复上述所有,直到数据都被拆分开停止。

三、时间复杂度

第一轮: 1个数组 2^0 1个数据到达正确位置

第二轮: 2个数组 2^1 2个数据到达正确位置

第三轮:4 个数组 2^2 4个数据到达正确位置

...

第k轮: 2^(k-1)个数组 2^(k-1)个数据到达正确的位置

x=1+2+4+...+2^(k-1)

x=2^k-1

k=log2x

O(nlogn)


四、代码

代码

java 复制代码
package com.lojarro.排序;

import java.util.Arrays;

public class QuickSort {
	public static void main(String[] args) {
		int[] arr= {5,7,4,2,0,3,1,6};
		sort(arr,0,arr.length-1);
		System.out.println(Arrays.toString(arr));
	}
	public static void sort(int[] arr,int left,int right) {
		if(left>=right) {
			return;
		}	
		//定义变量保存基准数
		int base=arr[left];
		//定义i游标j游标
		int i=left;
		int j=right;
		
		while(i!=j) {
			//j游标从后往前移动,找比基准数小的
			while(arr[j]>=base&& i<j) {
				j--;
			}
			while(arr[i]<=base&&i<j) {
				i++;
			}
			//i和j进行交换
			int temp=arr[i];
			arr[i]=arr[j];
			arr[j]=temp;
			
		}
		//i和j相遇 基准数和相遇位置进行交换
		arr[left]=arr[i];
		arr[i]=base;
		
		//排序左边
		sort(arr,left,i-1);
		//排序右边
		sort(arr,i+1,right);
	}
}

内存图

相关推荐
汀、人工智能7 小时前
[特殊字符] 第40课:二叉树最大深度
数据结构·算法·数据库架构·图论·bfs·二叉树最大深度
赫瑞8 小时前
数据结构中的排列组合 —— Java实现
java·开发语言·数据结构
大熊背8 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
yuannl1012 小时前
数据结构----队列的实现
数据结构
Mr_Xuhhh12 小时前
从ArrayList到LinkedList:理解链表,掌握Java集合的另一种选择
java·数据结构·链表
Ricardo-Yang14 小时前
SCNP语义分割边缘logits策略
数据结构·人工智能·python·深度学习·算法
soragui15 小时前
【Python】第 4 章:Python 数据结构实现
数据结构·windows·python
samroom15 小时前
【鸿蒙应用开发 Dev ECO Studio 5.0版本】从0到1!从无到有!最全!计算器------按钮动画、滑动退格、中缀表达式转后缀表达式、UI设计
数据结构·ui·华为·typescript·harmonyos·鸿蒙
算法鑫探15 小时前
10个数下标排序:最大值、最小值与平均值(下)
c语言·数据结构·算法·排序算法·新人首发
王老师青少年编程16 小时前
csp信奥赛c++之状压枚举
数据结构·c++·算法·csp·信奥赛·csp-s·状压枚举