欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

圖解Java排序算法之快速排序的三數(shù)取中法

 更新時(shí)間:2021年11月04日 15:26:02   作者:dreamcatcher-cx  
這篇文章主要為大家詳細(xì)介紹了Java排序算法之快速排序的三數(shù)取中法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

基本步驟

三數(shù)取中

在快排的過程中,每一次我們要取一個(gè)元素作為樞紐值,以這個(gè)數(shù)字來將序列劃分為兩部分。在此我們采用三數(shù)取中法,也就是取左端、中間、右端三個(gè)數(shù),然后進(jìn)行排序,將中間數(shù)作為樞紐值。

根據(jù)樞紐值進(jìn)行分割

 

代碼實(shí)現(xiàn)

package sortdemo;
import java.util.Arrays;
/**
 * Created by chengxiao on 2016/12/14.
 * 快速排序
 */
public class QuickSort {
    public static void main(String[] args) {
        int[] arr = {9, 8, 7, 6, 5, 4, 3, 2, 1, 0};
        quickSort(arr, 0, arr.length - 1);
        System.out.println("排序結(jié)果:" + Arrays.toString(arr));
    }
    /**
     * @param arr
     * @param left  左指針
     * @param right 右指針
     */
    public static void quickSort(int[] arr, int left, int right) {
        if (left < right) {
            //獲取樞紐值,并將其放在當(dāng)前待處理序列末尾
            dealPivot(arr, left, right);
            //樞紐值被放在序列末尾
            int pivot = right - 1;
            //左指針
            int i = left;
            //右指針
            int j = right - 1;
            while (true) {
                while (arr[++i] < arr[pivot]) {
                }
                while (j > left && arr[--j] > arr[pivot]) {
                }
                if (i < j) {
                    swap(arr, i, j);
                } else {
                    break;
                }
            }
            if (i < right) {
                swap(arr, i, right - 1);
            }
            quickSort(arr, left, i - 1);
            quickSort(arr, i + 1, right);
        }
    }
    /**
     * 處理樞紐值
     *
     * @param arr
     * @param left
     * @param right
     */
    public static void dealPivot(int[] arr, int left, int right) {
        int mid = (left + right) / 2;
        if (arr[left] > arr[mid]) {
            swap(arr, left, mid);
        }
        if (arr[left] > arr[right]) {
            swap(arr, left, right);
        }
        if (arr[right] < arr[mid]) {
            swap(arr, right, mid);
        }
        swap(arr, right - 1, mid);
    }
    /**
     * 交換元素通用處理
     *
     * @param arr
     * @param a
     * @param b
     */
    private static void swap(int[] arr, int a, int b) {
        int temp = arr[a];
        arr[a] = arr[b];
        arr[b] = temp;
    }
}

排序結(jié)果

[1, 2, 3, 4, 5, 6, 7, 8]

總結(jié)

快速排序是一種交換類的排序,它同樣是分治法的經(jīng)典體現(xiàn)。在一趟排序中將待排序的序列分割成兩組,其中一部分記錄的關(guān)鍵字均小于另一部分。然后分別對(duì)這兩組繼續(xù)進(jìn)行排序,以使整個(gè)序列有序。在分割的過程中,樞紐值的選擇至關(guān)重要,本文采取了三位取中法,可以很大程度上避免分組"一邊倒"的情況??焖倥判蚱骄鶗r(shí)間復(fù)雜度也為O(nlogn)級(jí)。

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • JDK12的新特性之teeing collectors

    JDK12的新特性之teeing collectors

    這篇文章主要介紹了JDK12的新特性之teeing collectors的相關(guān)資料,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • SpringBoot接入支付寶支付的方法步驟

    SpringBoot接入支付寶支付的方法步驟

    這篇文章主要介紹了SpringBoot接入支付寶支付的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Java實(shí)現(xiàn)求數(shù)組最長(zhǎng)子序列算法示例

    Java實(shí)現(xiàn)求數(shù)組最長(zhǎng)子序列算法示例

    這篇文章主要介紹了Java實(shí)現(xiàn)求數(shù)組最長(zhǎng)子序列算法,涉及java針對(duì)數(shù)組的遞歸遍歷、判斷相關(guān)操作技巧,需要的朋友可以參考下
    2018-07-07
  • Java 隨機(jī)生成任意組電話號(hào)碼過程解析

    Java 隨機(jī)生成任意組電話號(hào)碼過程解析

    這篇文章主要介紹了Java 隨機(jī)生成任意組電話號(hào)碼過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • MyBatis中association的基本使用方法

    MyBatis中association的基本使用方法

    在項(xiàng)目中某些實(shí)體類之間肯定有關(guān)鍵關(guān)系,比如一對(duì)一,一對(duì)多等,在hibernate中用one to one和one to many,而mybatis中就用association和collection,下面這篇文章主要給大家介紹了關(guān)于MyBatis中association基本使用方法的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • Java中斷一個(gè)線程操作示例

    Java中斷一個(gè)線程操作示例

    這篇文章主要介紹了Java中斷一個(gè)線程操作,結(jié)合實(shí)例形式分析了java中斷線程相關(guān)的interrupt()、isInterrupted()及interrupted()函數(shù)使用技巧,需要的朋友可以參考下
    2019-10-10
  • Spring Boot 項(xiàng)目啟動(dòng)自動(dòng)執(zhí)行方法的兩種實(shí)現(xiàn)方式

    Spring Boot 項(xiàng)目啟動(dòng)自動(dòng)執(zhí)行方法的兩種實(shí)現(xiàn)方式

    這篇文章主要介紹了Spring Boot 項(xiàng)目啟動(dòng)自動(dòng)執(zhí)行方法的兩種實(shí)現(xiàn)方式,幫助大家更好的理解和學(xué)習(xí)使用Spring Boot框架,感興趣的朋友可以了解下
    2021-05-05
  • Java實(shí)現(xiàn)PDF轉(zhuǎn)Word的示例代碼(無水印無頁數(shù)限制)

    Java實(shí)現(xiàn)PDF轉(zhuǎn)Word的示例代碼(無水印無頁數(shù)限制)

    這篇文章主要為大家詳細(xì)介紹了如何利用Java語言實(shí)現(xiàn)PDF轉(zhuǎn)Word文件的效果,并可以無水印、無頁數(shù)限制。文中的示例代碼講解詳細(xì),需要的可以參考一下
    2022-05-05
  • Synchronized?和?ReentrantLock?的實(shí)現(xiàn)原理及區(qū)別

    Synchronized?和?ReentrantLock?的實(shí)現(xiàn)原理及區(qū)別

    這篇文章主要介紹了Synchronized?和?ReentrantLock?的實(shí)現(xiàn)原理及區(qū)別,文章為榮啊主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • Spring Boot如何配置內(nèi)置Tomcat的maxPostSize值

    Spring Boot如何配置內(nèi)置Tomcat的maxPostSize值

    這篇文章主要介紹了Spring Boot如何配置內(nèi)置Tomcat的maxPostSize值方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08

最新評(píng)論