快速排序的简单理解

本文深入讲解了快速排序算法的实现原理,通过一个简洁的Java代码示例,演示了如何使用递归方法进行分治排序。文章详细解释了选择基准值、分区过程以及递归调用的细节。

快速排序的简单理解

public static int[] qsort(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) arr=qsort(arr,start,i-1);
    if (j+1<end) arr=qsort(arr,j+1,end);
    return (arr);
}

public static void main(String[] args) {
    int arr[] = new int[]{3,4,3,7,9,23,7};
    int len = arr.length-1;
    arr=qsort(arr,0,len);
    for (int i:arr) {
        System.out.print(i+"\t");
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值