在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

排序算法之“歸并算法”介紹

Android編程精選 ? 來源:Android編程精選 ? 2023-05-22 10:03 ? 次閱讀

在說這個題目之前先來說說一個排序算法 “歸并算法”

歸并算法采取思想是分治思想,分治思想簡單說就是分而治之,將一個大問題分解為小問題,將小問題解答后合并為大問題的答案。乍一看跟遞歸思想很像,確實如此,分治思想一般就是使用遞歸來實現的。但是需要注意的是:遞歸是代碼實現的方式,分治屬于理論。接下來看一副圖理解下:

8f07f4c4-f813-11ed-90ce-dac502259ad0.png

說完它的思想:我們再來分析下時間復雜度。歸并算法采用的是完全二叉樹的形式。所以可以由完全二叉樹的深度可以得知,整個歸并排序需要進行log2n次。

然后每一次需要消耗O{n}時間。所以總的時間復雜度為o{nlog2n}。歸并排序是一種比較占用內存,但是效率高且穩定的算法

貼上代碼:

static void Main(string[] args)
        {
            int[] arr = new int[] { 14,12,15,13,11,16 ,10};
 
            int[] newArr = Sort(arr, new int[7], 0, arr.Length - 1);
            for (int i = 0; i < newArr.Length - 1; i++)
            {
                Console.WriteLine(newArr[i]);
            }
 
            Console.ReadKey();
        }
 
        public static int[] Sort(int[] arr, int[] result, int start, int end)
        {
            if (start >= end)
                return null;
            int len = end - start, mid = (len >> 1) + start;
            int start1 = start, end1 = mid;
            int start2 = mid + 1, end2 = end;
            Sort(arr, result, start1, end1);
            Sort(arr, result, start2, end2);
            int k = start;
            //進行比較。注意這里++是后執行的,先取出來數組中的值然后++
            while (start1 <= end1 && start2 <= end2)
                result[k++] = arr[start1] < arr[start2] ? arr[start1++] : arr[start2++];
            //將每個分組剩余的進行復制
            while (start1 <= end1) 
                result[k++] = arr[start1++];
            //將每個分組剩余的進行復制
            while (start2 <= end2)
                result[k++] = arr[start2++]; 
            for (k = start; k <= end; k++)
                arr[k] = result[k];
            return result;
        }

說完了歸并算法回到題目上來 首先分析下 題目給定的是兩個已經排好序的數組合并,關鍵字“合并”,“兩個”,正好符合我們的歸并算法,并且已經分類好了,只需要去合并就可以了。

來看下幾張圖。

8f272d58-f813-11ed-90ce-dac502259ad0.png

藍色的箭頭表示最終選擇的位置,而紅色的箭頭表示兩個數組當前要比較的元素,比如當前是2與1比較,1比2小,所以1放到藍色的箭頭中,藍色的箭頭后移,1的箭頭后移。

8f58848e-f813-11ed-90ce-dac502259ad0.png

然后2與4比較,2比4小那么2到藍色的箭頭中,藍色箭頭后移,2后移,繼續比較.......

8f79e87c-f813-11ed-90ce-dac502259ad0.png

歸并思路就是這樣了,最后唯一需要注意的是那個先比較完的話,那么剩下的直接不需要比較,把后面的直接移上去就可以了,這個需要提前判定一下。

貼上代碼:

static void Main(string[] args)
        {
            int[] arr1 = new int[] { 2, 3, 6, 8 };
            int[] arr2 = new int[] { 1, 4, 5, 7 };
            int[] newArr = Sort(arr1, arr2);
            for (int i = 0; i < newArr.Length - 1; i++)
            {
                Console.WriteLine(newArr[i]);
            }
 
            Console.ReadKey();
        }
 
        public static int[] Sort(int[] arr1,int[] arr2)
        {
            int[] newArr = new int[arr1.Length + arr2.Length];
            int i = 0, j = 0, k = 0;
            while (i < arr1.Length && j < arr2.Length)
            {
                if (arr1[i] < arr2[j])
                {
                   
                    newArr[k] = arr1[i];
                    i++;
                    k++;
                }
                else
                {
                    
                    newArr[k] = arr2[j];
                    j++;
                    k++;
                }
            }
 
            while (i < arr1.Length)
                newArr[k++] = arr1[i++];
            while (j < arr2.Length)
                newArr[j++] = arr2[j++];
            return newArr;
        }
    }

審核編輯:彭靜
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 代碼
    +關注

    關注

    30

    文章

    4793

    瀏覽量

    68700
  • 二叉樹
    +關注

    關注

    0

    文章

    74

    瀏覽量

    12343
  • 排序算法
    +關注

    關注

    0

    文章

    53

    瀏覽量

    10080

原文標題:美團一面:兩個有序的數組,如何高效合并成一個有序數組?

文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    FPGA排序-冒泡排序介紹

    排序算法是圖像處理中經常使用一種算法,常見的排序算法有插入排序、希爾
    發表于 07-17 10:12 ?1112次閱讀
    FPGA<b class='flag-5'>排序</b>-冒泡<b class='flag-5'>排序</b><b class='flag-5'>介紹</b>

    十大排序算法總結

    排序算法是最經典的算法知識。因為其實現代碼短,應該廣,在面試中經常會問到排序算法及其相關的問題。一般在面試中最常考的是快速
    的頭像 發表于 12-20 10:39 ?1134次閱讀

    嵌入式stm32實用的排序算法 - 交換排序

    合很多,我這里就不再一一舉例說明,掌握排序的基本算法,到時候遇到就有用武之地。Ⅱ、排序算法分類1.按存儲分類:內部排序和外部
    發表于 04-12 13:14

    各種排序算法的時間空間復雜度、穩定性

    各種排序算法的時間空間復雜度、穩定性一、排序算法分類:二、排序算法比較:注:1、
    發表于 12-21 07:48

    介紹幾種常用的排序算法C實現

    文章目錄1、冒泡排序法2、選擇排序3、插入排序4、快速排序(快排)5、歸并排序1、冒泡排序
    發表于 12-21 06:31

    C語言教程之歸并排序

    C語言教程之歸并排序,很好的C語言資料,快來學習吧。
    發表于 04-22 11:06 ?0次下載

    C語言教程之幾種排序算法

    數據結構的排序算法有很多種。 其中, 快速排序 、希爾排序、堆排序、直接選擇排序不是穩定的
    發表于 11-16 10:23 ?1763次閱讀

    常用的排序算法總覽

    我們通常所說的排序算法往往指的是內部排序算法,即數據記錄在內存中進行排序
    的頭像 發表于 06-13 18:18 ?2839次閱讀
    常用的<b class='flag-5'>排序</b><b class='flag-5'>算法</b>總覽

    常用排序算法分析

    一種是比較排序,時間復雜度O(nlogn) ~ O(n^2),主要有:冒泡排序,選擇排序,插入排序歸并排序,堆
    的頭像 發表于 07-13 16:13 ?2170次閱讀

    實用的排序算法 - 交換排序

    實用的排序算法 - 交換排序
    的頭像 發表于 03-20 09:53 ?1751次閱讀
    實用的<b class='flag-5'>排序</b><b class='flag-5'>算法</b> -  交換<b class='flag-5'>排序</b>

    排序算法分享:歸并排序說明

    我們今天繼續給大家分享排序算法里面的另外一種排序算法歸并排序
    的頭像 發表于 12-24 14:34 ?780次閱讀

    解析數據結構的常用七大排序算法

    為了讓大家掌握多種排序方法的基本思想,本篇文章帶著大家對數據結構的常用七大算法進行分析:包括直接插入排序、希爾排序、冒泡排序、快速
    的頭像 發表于 03-16 08:22 ?1697次閱讀

    排序算法merge-sort的基礎知識

    本文介紹、解釋、評估和實現了排序算法merge-sort 。本文的目的是為您提供有關合并排序算法的可靠背景信息,該
    的頭像 發表于 04-07 17:54 ?2619次閱讀
    <b class='flag-5'>排序</b><b class='flag-5'>算法</b>merge-sort的基礎知識

    常見排序算法分類

    本文將通過動態演示+代碼的形式系統地總結十大經典排序算法排序算法 算法分類 —— 十種常見排序
    的頭像 發表于 06-22 14:49 ?921次閱讀
    常見<b class='flag-5'>排序</b><b class='flag-5'>算法</b>分類

    排序算法有哪些

    1. 歸并排序(遞歸版) 歸并排序(MERGE-SORT)是利用歸并的思想實現的排序方法,該算法采用經典的分治策略,即分為兩步:分與治。 分
    的頭像 發表于 10-11 15:49 ?621次閱讀
    <b class='flag-5'>排序</b><b class='flag-5'>算法</b>有哪些
    主站蜘蛛池模板: 亚洲欧洲一二三区| 天堂资源站| 天天寡妇色| 一区二区三区电影| 婷婷六月天激情| 色多多在线观看视频| 日本人色道| 欧美二区三区| 国产网站在线免费观看| 国产免费一级高清淫日本片| www九色| 天天看天天碰| 国产免费午夜高清| 激情六月丁香| 边做饭边被躁欧美三级小说| 性欧美高清强烈性视频| 日本成人免费| 韩国朴银狐诱感在线观看| 99久久婷婷免费国产综合精品| 天天综合网久久| 国产―笫一页―浮力影院xyz| 欧美另类高清xxxxx| 欧美精品一区二区三区在线播放 | 天天操天天干天天射| 久操视屏| 最新色站| 亚洲a影院| 免费的黄色大片| 天堂网在线看| 欧美日韩一日韩一线不卡| 国产一级真人毛爱做毛片| 午夜视频精品| 2018国产大陆天天弄| 久久久久久免费播放一级毛片| 天堂bt资源www在线| 精品爱爱| 视频在线精品| 在线成人精品国产区免费| 五月在线观看| 激情91| 濑亚美莉vs黑人欧美视频|