快速排序方法Java实现与分析
来源:互联网 发布:9月进出口数据 编辑:程序博客网 时间:2024/04/30 13:53
package paul;
/**
*<p>Title: 快速演算法</p>
*@author 良葛格
*@author paulliu
*/
public class QuickSort {
public QuickSort() {
}
/**
* printArray 用来跟踪了算法演算过程
*/
public static void printArray(int[] number) {
for(int k=0 ;k<number.length;k++){
System.out.print(number[k]);
System.out.print(" ");
}
System.out.print("/n");
}
/**
* sort 只是为了便于观察分析才设了这个方法,可有可无。
* @param number int[] 数组
*/
public static void sort(int[] number,String[] strNumber) {
sort(number,0,number.length-1);
//sortArr(number,0,number.length-1,strNumber);
//thirdsort(number,0,number.length-1,strNumber);
//sort(number,0,number.length-1);
}
/**
* sort
* 开始时,以左边第一个元素为轴
* @param number int[]
* @param left int
* @param right int
*/
public static void sort(int[] number, int left, int right) {
if(left<right)
{
int s=number[left];
int i=left;
int j=right+1;
while(true)
{
//令索引 i 從數列左方往右方找,直到找到大於 s 的數
while(i+1<number.length &&number[++i]<s);
//令索引 j 從數列右方往左方找,直到找到小於 s 的數
while(j>0&&number[--j]>s);
if(i>=j) break; //如果 i >= j,則離開迴圈
swap(number,i,j);//如果 i < j,則交換索引i與j兩處的值
}
//将左侧轴与j交换
number[left]=number[j];
number[j]=s;
sort(number,left,j-1);//轴左边进行递归
sort(number,j+1,right);//轴右边进行递归
}
}
private static void sortArr(int[] number, int left, int right,String[] strNumber) {
if(left<right)
{
int s=number[left];
int i=left;
int j=right+1;
while(true)
{
//令索引 i 從數列左方往右方找,直到找到大於 s 的數
while(i+1<number.length &&number[++i]<s);
//令索引 j 從數列右方往左方找,直到找到小於 s 的數
while(j>0&&number[--j]>s);
if(i>=j) break; //如果 i >= j,退出循环
//swap(number,i,j);//如果 i < j,則交換索引i與j兩處的值
swapstr(number,strNumber,i,j);
}
//将左侧轴与j交换
number[left]=number[j];
number[j]=s;
sortArr(number,left,j-1,strNumber);//轴左边进行递归
sortArr(number,j+1,right,strNumber);//轴右边进行递归
}
}
/**
* provesortfirst
* 以中间的元素为轴
* @param number int[]
* @param left int
* @param right int
*/
public static void provesortfirst(int[] number, int left, int right) {
if(left < right) {
int s = number[(right+left)/2];
int i = left - 1;
int j = right + 1;
while(true) {
// 向右找
while(number[++i] < s) ;
// 向左找
while(number[--j] > s) ;
if(i >= j)
break;
swap(number, i, j);
}
provesortfirst(number, left, i-1);
provesortfirst(number, j+1, right);
}
}
private static void thirdsort(int[] number,int left, int right,String[] strNumber)
{
if(left < right) {
int q = partition(number, left, right,strNumber);
thirdsort(number, left, q-1,strNumber);
thirdsort(number, q+1, right,strNumber);
}
}
/**
*
* @param number int[]
* @param left int
* @param right int
* @return int
*/
private static int partition(int number[],int left, int right,String[] strNumber)
{
int s = number[right]; //先以右边最后一个为轴
int i = left - 1;
for(int j = left; j < right; j++)
{ if(number[j] >= s)
{ i++;
swapstr(number,strNumber,i,j);
}
}
swapstr(number,strNumber,i+1, right);
return i+1;
}
/**
* swap
* 交换值方法
* @param number int[]
* @param i int
* @param j int
*/
private static void swap(int[] number, int i, int j) {
int t;
t=number[i];
number[i]=number[j];
number[j]=t;
}
/**
* swapstr
*
* @param strNumber String[]
* @param i int
* @param j int
*/
private static void swapstr(int[] number,String[] strNumber, int i, int j) {
String t;
t=strNumber[i];
strNumber[i]=strNumber[j];
strNumber[j]=t;
int m;
m=number[i];
number[i]=number[j];
number[j]=m;
}
}
- 快速排序方法Java实现与分析
- 快速排序实现与分析
- 快速排序分析与实现
- 数据结构与算法分析笔记与总结(java实现)--排序5:快速排序练习题
- 快速排序分析与C语言实现
- QuickSort 快速排序的分析与实现
- 快速排序的经典实现与分析
- 快速排序算法的分析与实现
- 快速排序(附Java实现和分析)
- java实现快速排序两种方法
- java两种方法实现快速排序
- 快速排序实现分析
- 排序算法—快速排序算法分析与实现(Python)
- 快速排序个人理解与java实现
- 数据结构---快速排序---java与c++实现
- 快速排序与堆排序的Java实现(泛型)
- Java 冒泡排序与快速排序的实现
- 算法设计与分析 快速排序的递归实现算法
- dddeeeeeeeeeeeeeeeeeee
- 异常处理类
- 北大清华令人很灰心
- 美国人至今也想不通
- 有多少爱可以胡来?有多少人可以恋爱?〉
- 快速排序方法Java实现与分析
- 喝酒
- DShow中实现抓图的几种方法
- DShow中调试方法 (收藏)
- Directshow(SDK)学习笔记九_视频捕捉
- 利用Directshow开发源Filter (收藏)
- 开发Transform filter 引用自(智慧的鱼 http://blog.csdn.net/aoosang/)
- 开发视频播放Filter
- Filter开发基础