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();
}
}
十六 快速排序
Posted Heaven of freedom
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了十六 快速排序相关的知识,希望对你有一定的参考价值。
以上是关于十六 快速排序的主要内容,如果未能解决你的问题,请参考以下文章
Java网络商城项目 SpringBoot+SpringCloud+Vue 网络商城(SSM前后端分离项目)十六(商品排序,Thymeleaf快速入门,商品详情页的展示)
Java网络商城项目 SpringBoot+SpringCloud+Vue 网络商城(SSM前后端分离项目)十六(商品排序,Thymeleaf快速入门,商品详情页的展示)