排序算法-Java實現快速排序算法

開篇介紹java

你們好,公衆號【Java極客思惟】近期會整理一些Java高頻面試題分享給小夥伴,也但願看到的小夥伴在找工做過程當中可以用獲得!本章節主要針對Java快速排序算法的實現進行分享。面試

首先,來看一下,快速排序的實現的動態圖:算法

快速排序介紹:數組

快速排序,根據教科書說法來看,是冒泡排序的一種改進。微信

快速排序,由一個待排序的數組(array),以及找準三個變量:ui

  • 中樞值(pivot)
  • 左值(left)
  • 右值(right)

根據中樞值(pivot)來作調整,將數組(array)分爲三個部分:spa

  • 第一部分中樞值(pivot),單獨數字構成,這個值在每次排序好的"最中間";
  • 第二部分左邊數組(由array的一部分組成),這個數組在第一部分 中樞值(pivot) 的"左邊",其中左邊數組中的每個值(不必定是排序好的,多是亂序的),都要比中樞值和右邊數組的值要小;
  • 第三部分右邊數組(由array的一部分組成),這個數組在第一部分 中樞值(pivot)的"右邊",其中右邊數組的每個值(不必定是排序好的,多是亂序的),都要比中樞值和左邊數組的值要大

以上就是快速排序要作的第一步,將數組按照:左邊數組 、 中樞值 、 右邊數組 區分開來。code

再根據 遞歸思想 , 對 左邊數組 、 中樞值 、 右邊數組 不斷遞歸循環操做,不斷拆分出三部分來,最終達到快速排序的效果。blog

核心邏輯:排序

快排算法遞歸調用:

接下來附上完整實現代碼:

public class QuickSort {

    /**
     * 快速排序調用方法
     *
     * @param ary   待排序數組
     * @param left  左值
     * @param right 右值
     * @return int值
     * @author Cansluck
     */
    public static int getSortNum(int[] ary, int left, int right) {
        // 定義一箇中樞值pivot,讓其等於數組的左值,樞軸選定後永遠不變,最終在中間,前小後大
        int pivot = ary[left];
        while (left < right) {
            // 看後面ary[right] > pivot比較,若是右邊數組值大於中樞值,說明不須要調整位置,則讓右值(right)自減1
            while (left < right && ary[right] >= pivot) {
                right--;  // 執行自減操做
            }
            // 若是上面循環不符合條件的,則說明右邊數組的一個值,小於中樞值(pivot),則將其替換到左邊數組中
            ary[left] = ary[right];
            // 看後面ary[left] < pivot比較,若是左邊數組值小於中樞值,說明不須要調整位置,則讓左值(left)自增1
            while (left < right && ary[left] <= pivot) {
                left++;  // 執行自增操做
            }
            // 若是上面循環不符合條件,則說明左邊數組的一個值,大於中樞值(pivot),則將其替換到右邊數組中
            ary[right] = ary[left];
        }
        // 最後將中樞值給自增後的左邊數組的一個值中
        ary[left] = pivot;
        // 返回左邊數組下標
        return left;
    }

    /**
     * 快速排序遞歸方法
     *
     * @author Cansluck
     * @param ary   待排序數組
     * @param left  左值
     * @param right 右值
     */
    public static void quickSort(int[] ary, int left, int right) {
        // 定義中樞值
        int pivot;
        // 判斷
        if (left < right) {
            // 根據方法獲得了每次中樞值的位置
            pivot = getSortNum(ary, left, right);
            // 根據中樞值(pivot),來對左邊數組進行遞歸調用快速排序
            quickSort(ary, left, pivot - 1);
            // 根據中樞值(pivot),來對右邊數組進行遞歸調用快速排序
            quickSort(ary, pivot + 1, right);
        }
    }

    public static void main(String[] args) {
        int[] ary = {97, 58, 12, 88, 77, 22, 33, 44, 66, 22};
        quickSort(ary, 0, ary.length - 1);
        for (int i = 0; i < ary.length; i++) {
            if (i != ary.length - 1)
                System.out.print(ary[i] + ", ");
            else
                System.out.println(ary[i]);
        }
    }
}

以上就是快速排序的詳細介紹及完整實現。有興趣的小夥伴也自行實現如下吧~


點關注、不迷路

若是以爲文章不錯,歡迎關注點贊收藏,大家的支持是我創做的動力,感謝你們。

若是文章寫的有問題,請不要吝嗇,歡迎留言指出,我會及時覈查修改。

若是你還想更加深刻的瞭解我,能夠微信搜索「Java極客思惟」進行關注。天天8:00準時推送技術文章,讓你的上班路不在孤獨,並且每個月還有送書活動,助你提高硬實力!

相關文章
相關標籤/搜索