1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Java实现快速排序 Quick Sort

Java实现快速排序 Quick Sort

时间:2020-10-12 08:47:21

相关推荐

Java实现快速排序 Quick Sort

本文带来八大排序算法之快速排序算法。

快速排序(QuickSort)是对冒泡排序的一种改进。基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程通过递归进行,以此达到整个数据变成有序序列。

因此快速排序有一个重要概念就是分区。如何分区,则需要找一个中轴值(pivot),不同的版本的快速排序算法对中轴值pivot的选择不同:

1.总是选择第一个元素为中轴值pivot;

2.总是选择最后一个元素为中轴值pivot;

3.随机选择一个元素为中轴值pivot;

4.选择中间的元素为中轴值pivot(本文下面的代码按此选择)

代码实现:

import java.util.Arrays;public class QuickSort {public static void main(String[] args){int[] arr = {-9, 78, 0, 23, -567, 70};quickSort(arr, 0, arr.length-1);System.out.println(Arrays.toString(arr));}public static void quickSort(int[] arr, int left, int right){int l = left; //用于记录左下标int r = right; //用于记录右下标int pivot = arr[(left + right) / 2]; //中轴值int temp = 0; //临时变量 作为交换时使用//while循环目的是让 比pivot小的值放到其左边//比pivot大的放到右边while(l < r){//在pivot的左边一直找,找到大于等于pivot值,才退出while(arr[l] < pivot){l = l + 1;}//在pivot的右边一直找,找到小于等于pivot值,才退出while(arr[r] > pivot){r = r - 1;}//如果 l>= r 说明pivot的左右两边的值,已经按照//左边全部是小于等于pivot,右边全部是大于等于pivot的值if(l >= r){break;}//交换temp = arr[l];arr[l] = arr[r];arr[r] = temp;//如果交换完之后,发现arr[l] == pivot , r-- 前移if(arr[l] == pivot){r = r - 1;}//如果交换完之后,发现arr[r] == pivot , l++ 后移if(arr[r] == pivot){l = l + 1;}}//如果 l == r , 必须 l++, r--, 否则出现栈溢出if(l == r){l = l + 1;r = r - 1;}//向左递归if(left < r){quickSort(arr, left, r);}//向右递归if(right > l){quickSort(arr, l, right);}}}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。