您的位置:首页 > 编程语言 > Java开发

快速排序java

2017-07-06 12:00 225 查看
package jianzhioffer;
import java.util.Arrays;
public class QuickSort {
// 一次排序
public static int partition(int data[], int start, int end) {
if (data.length <= 0 || start < 0 ) {
System.err.println("不合法");
}
int key = start;
int value = data[0];
while (start != end) {
if (key<end) {
if (value < data[end]) {
swap(data, key, end);
key = end;
} else {
end--;
}
} else {
if (value > data[start]) {
swap(data, start, key);
key = start;
} else {
start++;
}
}

}
return key;
}
//交换数组元素
public static void swap(int data[], int i, int j) {
data[i] ^= data[j];
data[j] = data[i] ^ data[j];
data[i] ^= data[j];
}
//递归排序左右子序列
public static void quickSort(int[] data, int start, int end) {
if (start == end) {
return;
}
int key = partition(data, start, end);
if(key<end)
quickSort(data, key+1, end);
if(key>start)
quickSort(data, start, key-1);
}
//测试
public static void main(String[] args) {
int[] data = new int[] { 2, 5, 1, 5, 7, 8 };
quickSort(data, 0, data.length - 1);
System.out.println(Arrays.toString(data));
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: