亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java版十大排序經(jīng)典算法:完整代碼(3)

 更新時間:2021年07月27日 09:35:33   作者:牛哄哄的柯南  
優(yōu)秀的文章也不少,但是Java完整版的好像不多,我把所有的寫一遍鞏固下,同時也真誠的希望閱讀到這篇文章的小伙伴們可以自己去從頭敲一遍,不要粘貼復(fù)制!希望我的文章對你有所幫助,每天進步一點點

歸并排序

簡單解釋:該算法是采用分治法,把數(shù)組不斷分割,直至成為單個元素,然后比較再合并(合并的過程就是兩部分分別從頭開始比較,取出最小或最大元素的放到新的區(qū)域內(nèi),繼續(xù)取兩部分中最大或最小的元素,直到這兩部分合并完,最后所有的都合并完,最后形成完整的有序序列)

完整代碼:

package com.keafmd.Sequence;
/**
 * Keafmd
 *
 * @ClassName: MergeSort
 * @Description: 歸并排序
 * @author: 牛哄哄的柯南
 * @date: 2021-06-24 10:35
 */
public class MergeSort {
    //歸并排序
    public static void mergeSort(int []arr ,boolean ascending){
        int[] temp = new int[arr.length]; //在排序前,先建好一個長度等于原數(shù)組長度的臨時數(shù)組,避免遞歸中頻繁開辟空間
        mergeSort(arr,0,arr.length-1,temp,ascending);
    }
    public static void mergeSort(int []arr){
        mergeSort(arr,true);
    }
    /**
     *
     * @param arr 傳入的數(shù)組
     * @param left 當(dāng)前子數(shù)組的起始下標(biāo)
     * @param right 當(dāng)前子數(shù)組的結(jié)束下標(biāo)
     * @param temp 拷貝暫存數(shù)組
     */
    public static void mergeSort(int []arr,int left,int right,int[] temp,boolean ascending){
        if(left<right){ //這里是遞歸結(jié)束的條件,我們是對半分,那當(dāng)left==right的時候肯定大家都是只有一個元素了。
            //對半分,比如總長度是10,left=0,right=9,mid=4確實是中間分了,0~4,5~9
            //當(dāng)長度9,left=0,right=8,mid=4,0~4,5~8
            int mid = left + (right-left)/2; // 防止越界的寫法
            //int mid = (left+right)/2;
            mergeSort(arr,left,mid,temp,ascending); //左邊歸并排序,使得左子序列有序
            mergeSort(arr,mid+1,right,temp,ascending); //右邊歸并排序,使得右子序列有序
            merge(arr,left,mid,right,temp,ascending); //將兩個有序子數(shù)組合并操作
        }
    }
    private static void merge(int[] arr,int left,int mid,int right,int[] temp,boolean ascending){
        int i = left; //左序列起始下標(biāo)
        int j = mid+1; //右序列起始下標(biāo)
        int t = 0; //臨時數(shù)組指針
        while(i<=mid&&j<=right){
            if(ascending?arr[i]<arr[j]:arr[i]>arr[j]){ //比較兩個序列第一個元素誰小,誰小先拷貝誰到temp,然后對應(yīng)子序列下標(biāo)加1
                temp[t++] = arr[i++];
            }else {
                temp[t++] = arr[j++];
            }
        }
        while(i<=mid){ //將左邊剩余元素填充進temp中——左序列有一些數(shù)總是比右邊的大的數(shù)
            temp[t++] = arr[i++];
        }
        while(j<=right){ //將右序列剩余元素填充進temp中——右序列有一些數(shù)總是比左邊的大的數(shù)
            temp[t++] = arr[j++];
        }
        t = 0;
        //將temp中的元素全部拷貝到原數(shù)組中
        while(left<=right){
            arr[left++] = temp[t++];
        }
    }
}

插入排序

簡單解釋:最簡單的理解就是打地主時我們拿到牌后的整理過程,從第二個牌(假設(shè)我們拿起來這個牌開始比較)開始,(說下升序)從后往前比較如果比前面的那個牌小,就把牌往后移動,直到找到一個合適的位置(這個位置的前面的那個牌不比這個要放下的牌大)就把這個牌放到這個位置,慢慢的前面的部分變得有序,直至全部有序即可。

完整代碼:

package com.keafmd.Sequence;
/**
 * Keafmd
 *
 * @ClassName: StraghtInsertSort
 * @Description: 插入排序
 * @author: 牛哄哄的柯南
 * @date: 2021-06-24 10:36
 */
public class StraghtInsertSort {
    //插入排序
    public static void straghtInsertSort(int[] arr) {
        straghtInsertSort(arr, true);//默認進行升序
    }
    public static void straghtInsertSort(int[] arr, boolean ascending) {
        for (int i = 1; i < arr.length; i++) {
            int temp = arr[i];
            int j=0; //這就是那個合適的位置
            for (j = i - 1; j >= 0 && (ascending ? temp < arr[j] : temp > arr[j]); j--) {
                arr[j + 1] = arr[j];
            }
            //把牌放下,為啥是j+1,
            //是因為上面的循環(huán)遍歷到不符合情況的時候 j是合適的位置的前面的那個數(shù)的位置
            //有點拗口,但是就是這個意思,看圖方便理解下
            arr[j + 1] = temp;

        }
    }
}

希爾排序

簡單解釋:希爾排序是插入排序的改進版,我們理解一個叫做下標(biāo)差的的東西,也就是下面那個圖中的增量d,初始下標(biāo)差為arr.length/2,然后繼續(xù)/2,對在同一下標(biāo)差(相當(dāng)于把這幾個數(shù)單獨拿出來了)的若干個數(shù)進行插入排序即可。

完整代碼:

package com.keafmd.Sequence;
/**
 * Keafmd
 *
 * @ClassName: ShellSort
 * @Description: 希爾排序
 * @author: 牛哄哄的柯南
 * @date: 2021-06-24 10:39
 */
public class ShellSort {
    public static void shellSort(int[] arr) {
        shellSort(arr,true);
    }
    public static void shellSort(int[] arr,boolean ascending) {
        for(int d = arr.length/2;d>0;d/=2){
            for(int i=d;i< arr.length;i++){
                int temp = arr[i];
                int j=0;
                for(j=i-d;j>=0&&(ascending?temp<arr[j]:temp>arr[j]);j-=d){
                    arr[j+d]=arr[j];
                }
                arr[j+d] = temp;
            }
        }
    }
}

總結(jié)

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

相關(guān)文章

  • SpringBoot項目后端開發(fā)邏輯全面梳理

    SpringBoot項目后端開發(fā)邏輯全面梳理

    這篇文章主要介紹了SpringBoot項目后端開發(fā)邏輯全面梳理,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Hibernate連接三種數(shù)據(jù)庫的配置文件

    Hibernate連接三種數(shù)據(jù)庫的配置文件

    今天小編就為大家分享一篇關(guān)于Hibernate連接三種數(shù)據(jù)庫的配置文件,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • spring cloud學(xué)習(xí)入門之config配置教程

    spring cloud學(xué)習(xí)入門之config配置教程

    這篇文章主要給大家介紹了關(guān)于spring cloud學(xué)習(xí)入門之config配置的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用spring cloud具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • 用Java編寫一個簡單的拼圖游戲全過程

    用Java編寫一個簡單的拼圖游戲全過程

    拼圖游戲是一種智力類游戲,玩家需要將零散的拼圖塊按照一定的規(guī)律組合起來,最終拼成完整的圖案,這篇文章主要給大家介紹了關(guān)于用Java編寫一個簡單的拼圖游戲,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-06-06
  • SpringBoot 多數(shù)據(jù)源及事務(wù)解決方案小結(jié)

    SpringBoot 多數(shù)據(jù)源及事務(wù)解決方案小結(jié)

    本文主要介紹了多數(shù)據(jù)源管理的解決方案(應(yīng)用層事務(wù),而非XA二段提交保證),以及對多個庫同時操作的事務(wù)管理,具有一定的參考價值,感興趣的可以了解一下
    2024-06-06
  • 布隆過濾器詳解以及其在Java中的實際應(yīng)用

    布隆過濾器詳解以及其在Java中的實際應(yīng)用

    布隆過濾器是一種數(shù)據(jù)結(jié)構(gòu),比較巧妙的概率型數(shù)據(jù)結(jié)構(gòu)(probabilistic data structure),特點是高效地插入和查詢,這篇文章主要給大家介紹了關(guān)于布隆過濾器詳解以及其在Java中的實際應(yīng)用,需要的朋友可以參考下
    2023-12-12
  • IO 使用說明介紹

    IO 使用說明介紹

    本篇文章小編為大家介紹,IO 使用說明介紹。需要的朋友參考下
    2013-04-04
  • Java中Future接口詳解

    Java中Future接口詳解

    這篇文章主要介紹了Java中Future接口詳解,本文通過案例給大家詳細講解了Java中Future接口,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • 簡述springboot及springboot cloud環(huán)境搭建

    簡述springboot及springboot cloud環(huán)境搭建

    這篇文章主要介紹了簡述springboot及springboot cloud環(huán)境搭建的方法,包括spring boot 基礎(chǔ)應(yīng)用環(huán)境搭建,需要的朋友可以參考下
    2017-07-07
  • mybatisplus開啟sql打印的三種方式匯總

    mybatisplus開啟sql打印的三種方式匯總

    這篇文章主要介紹了mybatisplus開啟sql打印的三種方式,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01

最新評論