快速排序


快排思想

通过一趟排序将序列分成左右两部分,其中左半部分的的值均比右半部分的值小,然后再分别对左右部分的记录进行排序,直到整个序列有序

代码及思路

public class Quick {  //通过一趟排序将序列分成左右两部分,其中左半部分的的值均比右半部分的值小,
                     //然后再分别对左右部分的记录进行排序,直到整个序列有序
 public static void main(String[] args){
     int[] arr = {6,3,7,9,5,1,4};
     quickSort(arr,0,arr.length-1);
     //输出排序好的数组
     System.out.println(Arrays.toString(arr));
 }
 public static void quickSort(int[] arr,int left,int right){
     if(left > right){
         return;
     }
     //定义变量保存基准数
     int base = arr[left];
     //定义变量i,指向最左边
     int i = left;
     //定义变量i,指向最右边
     int j = right;
     //当i和j不相遇的时候,在循环中进行检索
     while (i != j){
         //向由j从右往左检索比基准数小的,如果检索到比基准数小的就停下
         //如果检索大于等于基准数就继续检索
         while (arr[j] >= base && i < j){
             j--;//j从右往左移动
         }
         //i从左往右检索
         while (arr[i] <= base && i < j){
             i++;//i从左往右移动
         }
         //代码走到这里,i停下了,j也停下了,然后交换i和j位置上的元素
         int temp = arr[i];
         arr[i] = arr[j];
         arr[j] = temp;
     }
     //如果上面while循环的条件不成立,会跳出这个循环,往下执行,
     //如果这个条件不成立说明i和j相遇了
     //如果i和j相遇了,就交换基准数这个元素和相遇位置的元素
     //把相遇位置的元素赋值给基准数这个位置的元素
     arr[left] = arr[i];
     //把基准数赋值给相遇位置的元素
     arr[i] = base;
     //基准数在这里就归位了,左边的数字都比他小,右边的都比他大
     //排基准数的左边
     quickSort(arr,left,i-1);
     //排右边
     quickSort(arr,j+1,right);
 }
 }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值