码迷,mamicode.com
首页 > 编程语言 > 详细

十六 、快速排序

时间:2018-03-02 14:43:37      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:ptr   排序   交换   分数   设置   sort   左移   blog   point   

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();
}

}

十六 、快速排序

标签:ptr   排序   交换   分数   设置   sort   左移   blog   point   

原文地址:https://www.cnblogs.com/fyz666/p/8492366.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!