java排序-交换排序-快速排序

Posted 浪川宣哲

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java排序-交换排序-快速排序相关的知识,希望对你有一定的参考价值。

优化前(传统):

 /**
     * 快速排序
     */
    @Test
    public void kuaiSuTest(){
        /**
         * 1、选择一个基点
         * 2、从两边开始向基点遍历,与基点比较,大小位置不对的就互换位置
         * 3、遍历结束排序完成
         */
        sort(data,0,data.length-1);
        System.out.println(Arrays.toString(data));

    }
    public static void sort(int[] data,int low,int height){
        int i = low;
        int j = height;
        if (i>j) {
            return;
        }
        int key=data[i];

        while (i<j){
            while (i<j&&data[j]>key){
                j--;
            }
            while (i<j&&data[i]<key){
                i++;
            }
            if (i<j){
                int temp = data[i];
                data[i]=data[j];
                data[j]=temp;
            }
        }
        sort(data,0,i-1);
        sort(data,i+1,height);
    }

优化:

在排序时,如果碰到了相同的元素比较多的时候也就是像{3,2,1,1,1,4,5,2,2,6,2,3}这种,我们判断的时候可以直接把这个元素放在与他相同的附近

 

以上是关于java排序-交换排序-快速排序的主要内容,如果未能解决你的问题,请参考以下文章

请给出java几种排序方法

Java 冒泡排序与快速排序的实现

java排序-交换排序-快速排序

数据结构之排序算法Java实现—— 交换类排序之快速排序算法

交换排序(冒泡排序快速排序的算法思想及代码实现)

冒泡排序和快速排序的Java实现