Java教程

算法与数据结构-快速排序

本文主要是介绍算法与数据结构-快速排序,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

思想:通过一趟排序将要排序的数据分割成独立的两部分:分割点左边都是比它小的数,右边都是比它大的数。

以一个数作为基点,运动左右指针将数据分隔

public class DemoApplication {
    public static void main(String[] args) {
        int arr[] = {6, 4, 20, 9, 44, 11, 0,2,23,10,17,3};
        //快速排序
        quickSort(arr,0, arr.length - 1);
        for(int k = 0; k < arr.length; k++){
            System.out.print(arr[k] + ",");
        }
    }
    /**
     * 快速排序
     */
    public static void quickSort(int arr[], int left, int right){
        //防止数组下标越界
        if(left < right){
            //得到基点对应下标
            int base = division(arr, left, right);
            quickSort(arr, left, base - 1);
            quickSort(arr, base + 1, right);
        }
    }

    public static int division(int[] arr, int left, int right){
        //临时存储基点值
        int base = arr[left];
        while(left < right){
            while(left < right && arr[right] >= base){
                right--;
            }
            arr[left] = arr[right];
            while(left < right && arr[left] < base){
                left++;
            }
            arr[right] = arr[left];
        }
        arr[left] = base;
        return left;
    }
}

参考地址:排序算法(5) -- 快速排序_Dby_freedom的博客-CSDN博客

这篇关于算法与数据结构-快速排序的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!