八大排序--08快速排序

现有 arr= {4,8,9,2,7}数组,请用快速排序的方式实现从小到大排序:

方法:

1.定义待排序数组中的第一个值为基准数;

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

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

4.i和j数值交换;

5.重复2-4步骤直到i和j相遇;

6.基准数和相遇位置的数据进行交换,交换完后的基准数到达正确位置;

7.以基准数为起始点,分为左右两部分,重复上述1-6步骤,直至数据都被拆分开结束

完整代码:

java 复制代码
package Java.start;

import java.util.Arrays;

public class quickSort {
//快速排序
	public static void main(String[] args) {
		int[] arr= {4,8,9,2,7};
		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];
			//System.out.println(base+"base");
			int i=left;
			int j=right;
			while(i!=j) {
			//	j游标从后向前移动,找比基准数更小的
			
			while(arr[j]>=base&&i<j) {
				j--;
			}
			//i游标从前向后移动,找比基准数更大的
			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);
		
		
	}
		
}

结果:

相关推荐
WolfGang0073212 分钟前
代码随想录算法训练营 Day47 | 图论 part05
算法·图论
我是无敌小恐龙2 分钟前
Java SE 零基础入门Day06 方法重载+Debug调试+String字符串全套API详解(超全干货)
java·开发语言·人工智能·python·transformer·无人机·量子计算
xiaoye37084 分钟前
java接口文档工具 swagger2和swagger3对比
java·服务器·前端
三维频道5 分钟前
工业级三维扫描实测:汽车灯具复杂结构件的全尺寸 3D 测量方案分析
java·人工智能·python·数码相机·3d·汽车·汽车轻量化制造
tongyiixiaohuang7 分钟前
基于轻易云的数据集成,实现企业系统间灵活对接
java·前端·数据库
李李李勃谦9 分钟前
基于鸿蒙PC多窗口特性的笔记管理工具开发实践
笔记·华为·harmonyos
猿长大人9 分钟前
算法 | 轮廓提取随笔 —— 关于像素、阈值和直觉的碎碎念
图像处理·算法
码农飞哥12 分钟前
从Java后端到AI应用开发,我这两年做了什么
java·开发语言·人工智能
啦啦啦_999916 分钟前
1. 线性回归之 向量&矩阵
算法·矩阵·线性回归
森林猿17 分钟前
IDEA-控制台乱码
java·ide·intellij-idea