排序算法之快速排序(Java实现)

本文深入讲解了快速排序算法,一种高效的排序方式,通过不断递归将数组分为两部分,一部分的所有元素都小于另一部分,从而实现整体排序。文章详细解释了如何选取基准元素并进行分区的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

快速排序是一种交换排序,这种排序的思想是把数组通过不断的递归,把数组中的数据分成两部分,前半部分小于某一个数,后半部分大于这个数,接着再对这两部分分别使用这种思想进行交换排序。这种排序的重点在于理解:局部排好序,那么整体就排好序了。

那么,如何把数据分成两部分,这里有个简单的办法,每次取数组中的第一个下标为low=0的元素,作为基准temp,然后通过从数组末端下标为high开始找比他小的元素,如果找到,那么nums[low]=nums[high],这一步只是把高位上的元素移到低位,高位空出来,接着从低位开始找比temp大的元素,如果找到,则将刚才空出的高位填上这个低位的数据,nums[high]=nums[low],当low=high的时候,再将这个位置填上temp,nums[low]=temp,这时候数组中已经分成了两部分,下一次从这个位置两边开始递归。

package com.xxx.algorithm.sort;

public class QuickSort {

	public static void quickSort(int[] nums,int low,int high){
		if(low<high){
			int middle = getMiddle(nums, low, high);
			quickSort(nums, low, middle-1);
			quickSort(nums, middle+1, high);
		}
	}
	
	public static int getMiddle(int[] nums,int low,int high){
		int temp = nums[low];
		while(low<high){
			while(low<high && nums[high] > temp){
				high--;
			}
			nums[low] = nums[high];
			while(low<high && nums[low]<temp){
				low++;
			}
			nums[high] = nums[low];
		}
		nums[low] = temp;
		return low;
	}
	
	
	
	public static void main(String[] args) {
		int data[] = {5,2,3,4,1,7,9,8,6,0,120,100};
		quickSort(data, 0, 11);
		System.out.println();
		for(int i=0;i<data.length;i++){
			System.out.print(data[i]+" ");
		}
	}

}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

luffy5459

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值