快速排序的思想
快速排序的思想可以通过四句话来描述:
- 确定中轴值pivot
- 将大于pivot的值放到其右边
- 将小于pivot的值放到其左边
- 对左右子序列重复前三步,即递归
具体的原理视频推荐:我认为讲的最好的快速排序视频
快速排序的性质
- 平均时间复杂度:O(n*logn)
- 最差时间复杂度:O(n^2)
- 不稳定。即排序前两个相等的数A和B,A在B的前面,但是在排序之后可能变为B在A的前面
快速排序的代码实现——以首元素为中轴值
public static void quickSort1(int[] arr,int left,int right){
if (left > right){
return;
}
int l = left;
int r = right;
int pivot = arr[left];//将首元素设为中轴值
int temp = 0;
while(l != r){
while(arr[r] > pivot && l< r){
r--;
}
while(arr[l] < pivot && l<r){
l++;
}
temp = arr[r];
arr[<

:快速排序&spm=1001.2101.3001.5002&articleId=115112893&d=1&t=3&u=0135dc368050451da19ba8e234409916)
208

被折叠的 条评论
为什么被折叠?



