快速排序

快速排序算法思想

在数组中选取一个数(一般都是选第一个数),分别与其它的每一个数比较,把比这个数小的数放到它的前面,比他大的数放到它的后面,此时数组分成两部分,该数前面的都比它小,后面的都比它大,然后分别对这两部分递归排序算法,就可以实现整个数组的排序。
在这里插入图片描述

/*
*任取一个元素 (如第一个) 为中心
*所有比它小的元素一律前放,比它大的元素一律后放,形成左右两个子表;
*对各子表重新选择中心元素并依此规则调整,直到每个子表的元素只剩一个
*一趟排序过程后我们返回枢纽的位置
*/
public  static  void  main(String[] args) {
    int[] arr = {1,34,66,2,77,2,5,335,311,4,224,244,2,44,3};
    int left = 0;
    int right = arr.length -1;
    QuickSort quickSort = new QuickSort();
    quickSort.Quick(arr,left,right);
    System.out.println(Arrays.toString(arr));
}


public int partition(int A[], int left, int right) {
    //选择枢纽元素
    int p = A[left];
    while (left < right) {
        //如果尾指针位置的数比枢纽数要大,移动尾指针的位置,否则就把所指示的值给首指针的位置
        while (left < right && A[right] >= p) {
            --right;
        }
        A[left] = A[right];
        //如果首指针位置的数比枢纽数要小,移动首指针的位置,否则就把所指示的值给尾指针的位置
        while (left < right && A[left] <= p) {
           ++left;
        }
        A[right] = A[left];
    }
     //此时的首尾指针已经相等,把枢纽的值赋给首尾指针相等的位置即可
     A[left] = p;
     return left;
}
     
//快速排序的递归
public void Quick(int A[], int left, int right) {
   //定义一个枢纽的位置
   int pnode;
   if (left < right) {
       pnode = partition(A, left, right);
      Quick(A, left, pnode - 1);
       Quick(A, pnode + 1, right);
   }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值