快速排序

此快速排序的思想是:
选取左边第一个元素作为【分界值】devided,每一趟排序目标是将所有比【分界值】devided数据元素小的放至其左边,所有比【分界值】大的元素放至其右边。然后再分别对左右的元素进行递归。



public class QuickSort
{

/**
* @param args
*/
public static void main(String[] args)
{
// TODO Auto-generated method stub
int[] a = {82, 16, 9, 95, 27, 75, 42, 69, 34};
quickSort(a, 0, a.length-1);
for(int b : a)
{
System.out.println(b);
}
}

public static void quickSort(int[] array, int left, int right)
{
int devided, temp, i, k, j;
if(left < right)
{
devided = left;
do
{
for(i=left+1; array[i]<array[devided] && i<=right;i++);//从右往左走,找出第一个比【分界值】大的array[i],跳出for循环,纪录array[i]
for(j=right;j>=left && array[j]>array[devided];j--);//从右往左走,找出第一个比【分界值】小的array[j],跳出for循环,纪录array[j]
if(i < j)swap(array, j, i);//交换array[i],array[j]。大的放到【分界值】右边,小的放左边。
}
while(i < j);//当ij交叉的时候,说明大小都排到右左了,跳出本次排序准备进入后面的递归。
swap(array, devided, j);
quickSort(array, left, j-1);
quickSort(array, i+1, right);
}
}
//交换数组中的元素,由于数组是引用,所以交换可以成功
public static void swap(int[] array, int a, int b)
{
int temp;
temp = array[a];
array[a] = array[b];
array[b] = temp;
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值