Java快速排序法怎么写
时间: 2023-03-14 19:35:01 浏览: 67
Java快速排序法的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。Java快速排序的代码实现如下:
public static void quickSort(int[] arr,int start,int end){
int pivot = arr[start];
int i = start;
int j = end;
while(i<j){
while((i<j)&&(arr[j]>pivot)){
j--;
}
while((i<j)&&(arr[i]<pivot)){
i++;
}
if((arr[i]==arr[j])&&(i<j)){
i++;
}else{
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
if(i-1>start) quickSort(arr,start,i-1);
if(j+1<end) quickSort(arr,j+1,end);
}
相关问题
java 中快速排序法
快速排序(Quick Sort)是一种常用且高效的排序算法,它通过分治的思想将一个大问题分解为若干个小问题进行解决。在 Java 中,可以使用递归来实现快速排序。
下面是一个简单的 Java 实现示例:
```java
public class QuickSort {
public static void quickSort(int[] arr, int low, int high) {
if (low < high) {
int pivot = partition(arr, low, high); // 划分操作,获取基准元素的位置
quickSort(arr, low, pivot - 1); // 对基准元素左边的子数组进行快速排序
quickSort(arr, pivot + 1, high); // 对基准元素右边的子数组进行快速排序
}
}
public static int partition(int[] arr, int low, int high) {
int pivot = arr[low]; // 选择第一个元素作为基准元素
while (low < high) {
while (low < high && arr[high] >= pivot) {
high--;
}
arr[low] = arr[high]; // 将比基准元素小的元素移到左边
while (low < high && arr[low] <= pivot) {
low++;
}
arr[high] = arr[low]; // 将比基准元素大的元素移到右边
}
arr[low] = pivot; // 将基准元素放入正确的位置
return low; // 返回基准元素的位置
}
public static void main(String[] args) {
int[] arr = {5, 2, 8, 9, 1, 3};
quickSort(arr, 0, arr.length - 1);
System.out.println(Arrays.toString(arr));
}
}
```
以上代码中,`quickSort` 方法用于实现快速排序,它首先通过 `partition` 方法将数组划分为两个部分,左边的部分小于等于基准元素,右边的部分大于等于基准元素。然后递归地对子数组进行快速排序。`partition` 方法选择第一个元素作为基准元素,通过双指针的方式将小于基准元素的元素移到左边,大于基准元素的元素移到右边,最后将基准元素放入正确的位置。
运行以上代码,输出结果为 `[1, 2, 3, 5, 8, 9]`,表示数组已经按照从小到大的顺序排序好了。
java的快速排序怎么写
快速排序的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。Java中快速排序的实现如下:public static void quickSort(int[] arr, int startIndex, int endIndex) {
// 检查数组是否为空
if (arr == null || arr.length < 2) {
return;
}
// 递归结束条件:startIndex大等于endIndex的时候
if (startIndex >= endIndex) {
return;
}
// 得到基准元素位置
int pivotIndex = partition(arr, startIndex, endIndex);
// 用分治法递归数列的两部分
quickSort(arr, startIndex, pivotIndex-1);
quickSort(arr, pivotIndex+1, endIndex);
}