91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java歸并排序算法的原理和作用

發布時間:2021-06-28 16:48:23 來源:億速云 閱讀:315 作者:chen 欄目:大數據

這篇文章主要介紹“java歸并排序算法的原理和作用”,在日常操作中,相信很多人在java歸并排序算法的原理和作用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”java歸并排序算法的原理和作用”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1、定義
    歸并排序是一種概念上最簡單的排序算法,與快速排序一樣,歸并排序也是基于分治法的。歸并排序將待排序的元素序列分
成兩個長度相等的子序列,為每一個子序列排序,然后再將他們合并成一個子序列。合并兩個子序列的過程也就是兩路歸并。

圖解(摘自網絡)

java歸并排序算法的原理和作用

2、代碼
public class TestController {

    public static void main(String[] args) {
        int[] a = { 49, 38, 65, 97, 76, 13, 27, 50 };
        mergeSort(a, 0, a.length-1);
        System.out.println("排好序的數組:" + Arrays.toString(a));

    }
    public static void mergeSort(int [] a,int start,int end){

        // 當子序列中只有一個元素時結束遞歸
        if(start<end){
            // 劃分子序列
            int mid=(start+end)/2;

            // 對左側子序列進行遞歸排序
            mergeSort(a, start, mid);

            // 對右側子序列進行遞歸排序
            mergeSort(a, mid+1, end);

            // 合并
            merge(a, start, mid, end);
        }
    }

    //兩路歸并算法,兩個排好序的子序列合并為一個子序列
    public static void merge(int []a,int left,int mid,int right){
        // 輔助數組
        int []tmp=new int[a.length];

        // p1、p2是檢測指針,k是存放指針
        int p1=left,p2=mid+1,k=left;

        while(p1<=mid && p2<=right){
            if(a[p1]<=a[p2])
                tmp[k++]=a[p1++];
            else
                tmp[k++]=a[p2++];
        }

        // 如果第一個序列未檢測完,直接將后面所有元素加到合并的序列中
        while(p1<=mid) {
            tmp[k++]=a[p1++];
        }
        // 如果第一個序列未檢測完,直接將后面所有元素加到合并的序列中
        while(p2<=right) {
            tmp[k++]=a[p2++];
        }

        // 復制回原素組
        for (int i = left; i <=right; i++) {
            a[i]=tmp[i];
        }
    }
}
3、結果
排好序的數組:[13, 27, 38, 49, 50, 65, 76, 97]

到此,關于“java歸并排序算法的原理和作用”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

浦县| 湖南省| 枣强县| 靖江市| 梅州市| 濮阳市| 濉溪县| 翼城县| 宁强县| 崇信县| 舟山市| 噶尔县| 池州市| 芦山县| 紫云| 常熟市| 富民县| 古交市| 桐庐县| 澄迈县| 缙云县| 靖安县| 新乡县| 万安县| 连城县| 郯城县| 佛山市| 洞头县| 阜城县| 江北区| 望江县| 西乌| 安陆市| 漠河县| 合阳县| 临武县| 库尔勒市| 郴州市| 微博| 邵阳市| 叙永县|