十六 、快速排序

public class QuickSort {


//划分数组
public static int partition(int[] array ,int left,int right,int point)
{
int leftptr = left -1;
int rightptr = right;

while(true)
{
//左边右移
while(leftptr<rightptr && array[++leftptr] < point);
//右边左移
while(leftptr < rightptr && array[--rightptr]>point);
if(leftptr >= rightptr)
break;
else
{
int tmp = array[leftptr];
array[leftptr] = array[rightptr];
array[rightptr] = tmp;
}

}
//将关键字与当前指向交换
int tmp = array[leftptr];
array[leftptr] = array[right];
array[right] = tmp;
return leftptr;
}


//快速排序
public static void sort(int[] array ,int left,int right)
{
if(left >= right)
return;
//设置关键字
int point = array[right];
//获得切入点,对数组进行划分
int partion = partition(array, left, right, point);
//对左边子数组进行快排
sort(array, left,partion -1);
//右边数组快排
sort(array, partion+1, right);

}

public static void display(int[] array)
{
System.out.print("[");
for(int num:array) //for的高级用法
{
System.out.print(num+" ");
}
System.out.print("]");
System.out.println();
}

}

转载于:https://www.cnblogs.com/fyz666/p/8492366.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值