国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

排序算法 之 歸并排序

2019-11-10 21:53:46
字體:
來源:轉載
供稿:網友

原文地址http://www.cnblogs.com/liukemng/p/3721125.html

歸并排序也是基于分治思想的一種排序算法,是通過對兩個或兩個以上的有序序列合并來實現的,對兩個序列合并的叫兩路歸并,對兩個以上序列合并的叫多路歸并。歸并排序的時間復雜度也為O(N*logN)。下面來看一下兩路歸并的實現:

基本思想:歸并排序時先找出序列的中間元素把序列分解為兩個子序列,對子序列重復這個過程直至把序列分解成為只包含單個元素的序列,然后把相鄰的序列兩兩合并使之有序,重復兩兩合并直至合并成為一個序列歸并結束序列有序。

代碼實現:

復制代碼
/// <summary>/// 歸并排序/// </summary>/// <param name="intArray"></param>/// <param name="left"></param>/// <param name="right"></param>public static void MergeSort(int[] intArray, int left, int right){    if (left < right)    {        int mid = (left + right) / 2;        MergeSort(intArray, left, mid);        MergeSort(intArray, mid + 1, right);        int[] temp = new int[right - left + 1];        int i = left, j = mid + 1, k = right, index = 0;        //同時循環數組的前半部分和后半部分并比較        while (i <= mid && j <= k)        {            if (intArray[i] <= intArray[j])                temp[index++] = intArray[i++];            else                temp[index++] = intArray[j++];        }        //如果前半部分沒有循環完        while (i <= mid)        {            temp[index++] = intArray[i++];        }        //如果后半部分沒有循環完        while (j <= k)        {            temp[index++] = intArray[j++];        }        //把臨時數組中的元素按順序拷貝回原數組        for (int copyIndex = 0; copyIndex < index; copyIndex++)        {            intArray[left + copyIndex] = temp[copyIndex];        }    }}復制代碼

當調用時left傳入序列開始的下標即0,right傳入序列結束的下標即(長度-1);

以上就是歸并排序的實現。


上一篇:jdbc之批處理

下一篇:STM32L152 STOP模式

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 绿春县| 宜丰县| 广灵县| 沂南县| 洛浦县| 长治市| 勐海县| 红安县| 扶风县| 屯昌县| 杭州市| 渝中区| 兴国县| 九龙县| 麻栗坡县| 蒲江县| 镇坪县| 巨野县| 常宁市| 内江市| 社旗县| 常宁市| 镇江市| 旺苍县| 松桃| 高台县| 芜湖市| 兰坪| 开封县| 郧西县| 天等县| 清水县| 法库县| 离岛区| 淳安县| 安顺市| 门头沟区| 华坪县| 东至县| 萨迦县| 藁城市|