Java数据结构与算法(排序)——快速排序

一、基本思想

  • 从数列中取一个元素,作为 “基准”(pivot);
  • 分区——遍历数组,将所有元素与基准值比较,小于基准值的放在基准前面,大于基准值的放在基准后面(等于基准值的可以到任一边)。一次分区完成后,该基准就位于数列的中间位置;
  • 递归对两个区的子数列进行排序,直至子数列的长度为 1。

二、代码实现

	public int[] quickSort(int[] sourceArray){
		// 复制数组
		int[] array = Arrays.copyOf(sourceArray, sourceArray.length);
		return sort(array, 0, array.length - 1);
	}
	
	private int[] sort(int[] array, int left, int right){
		if(left < right){
			int partitionIndex = partition(array, left, right);// 基准的下标
			sort(array, left, partitionIndex - 1);// 递归排序基准左边的序列
			sort(array, partitionIndex + 1, right);// 递归排序基准右边的序列
		}
		return array;
	}
	 
	/*
	 * 分区,返回值为基准的下标:
	 * 	以第一次分区操作为例:先以array[0]为基准,和剩余所有元素比较,小的往前走,大的往后走,
	 *  比较完成后,将基准交换至中间位置。一次分区后的结果就是:该基准处于数列的中间位置,所有元素
	 *  比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)
	 */
	private int partition(int[] array, int left, int right){
		int pivot = left;// 基准
		int index = pivot + 1;
		for (int i = index; i <= right; i++) {
			if(array[i] < array[pivot]){// 小于基准的往前走。注意:不是和基准交换
				swap(array, i, index);
				index++;
			}
		}
		/*
		 * 经过上面的for循环后,小于基准值的元素位于数组中(left + 1)到(index - 1)的位置,
		 * 大于基准值的元素位于数组中index到right的位置。最后再将(index - 1)和pivot位置
		 * 的元素交换,一次分区操作即完成,基准位于(index - 1)位置。
		 */
		swap(array, pivot, index - 1);// 把基准换至中间位置
		return index - 1;
	}
	
	// 交换
	private void swap(int[] array, int i, int j){
		int temp = array[i];
		array[i] = array[j];
		array[j] = temp;
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值