数据结构与算法(十一)排序---快速排序

快速排序法介绍:

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

代码实现


    /**
     * 快排
     * @param arr
     * @param left
     * @param right
     */
    public static void quickSort(int [] arr,int left ,int right){
        int l=left;
        int r=right;
        int privot=arr[(left+right)/2];

        int temp=0;
        while (l<r){
            while (arr[r]>privot){
                r--;
            }
            while (arr[l]<privot){
                l++;
            }
            if (l>=r){
                break;
            }
            temp=arr[l];
            arr[l]=arr[r];
            arr[r]=temp;
            if (arr[l]==privot){
                r--;
            }
            if (arr[r]==privot){
                l++;
            }
        }

        if (l==r){
            l++;
            r--;
        }
        if (left<r){
            quickSort(arr,left,r);
        }
        if (right>l) {
            quickSort(arr,l,right);
        }

    }
更新时间:2020-07-22 21:03:17

本文由 过去的,未来的 创作,如果您觉得本文不错,请随意赞赏
采用 知识共享署名4.0 国际许可协议进行许可
本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名
原文链接:https://www.fengpt.cn/archives/数据结构与算法排序---快速排序
最后更新:2020-07-22 21:03:17

评论

Your browser is out of date!

Update your browser to view this website correctly. Update my browser now

×