女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

3天內不再提示

排序算法里面的另外一種排序算法:歸并排序!

Q4MP_gh_c472c21 ? 來源:txp嵌入式 ? 作者:txp嵌入式 ? 2020-11-16 16:30 ? 次閱讀

今天繼續給大家分享排序算法里面的另外一種排序算法:歸并排序!

一、歸并排序:

1、歸并排序操作的核心思想:

a、確定分界點:mid=(l+r)/2

b、遞歸排序左邊和右邊(排完左右兩邊的數,就會成為兩個有序的序列了)

c、歸并(把上面的兩個有序序列合并成一個有序的序列,用一個簡單的詞來說,就是合二為一!)

2、舉例:

比如上圖我們有兩組已經排好的序列數字,我們要進行第三步合并,該如何進行呢?思路如下:

a、這里先定義一個空的數組res,它主要是為了臨時存放合并序列排序好的數字;我們從圖中可以看到,第一個序列指針i指向數字1,第二序列指針j指向2,這個時候我們要比較兩個數字的大小,小的數字就放到臨時數組res里面去,這里我們明顯知道數字1小于2,所以把1放到臨時數組res里去

b、然后指針i往下移動,如下圖所示,再次進行比較,明顯發現指針j指向的數字2更小,把它放到res里面去,然后指針j往下移動,指針i不動,后面依次類推

c、如下圖所示,兩個指針都指向了數字5,如果遇到兩個數字一樣的話,一般是把第一個序列的數字放到臨時數組res里面去,這點稍微要注意一下

d、最后把臨時數組里面的是數字放到原來的數組里面去

注意:一個算法穩定,并不能說它的時間效率是穩定的;這里的穩定是說兩個序列中有兩個數是相同的,如果在排完序之后,他們的位置還是沒有發生變化的話,那么這個排序就是穩定的,反之亦然!

3、歸并排序的平均時間復雜度的計算推導:

注:圖片來源:https://visualgo.net/zh/sorting

從圖片的縱性來分析,當拆解到1的時候,這個時候什么數等于n除于它等于1,通過計算,我們知道是logn,然后再從橫向分析,我們要最多比較n個數字,所以歸并排序的時間復雜度就是:nlogn

二、代碼示例:

代碼:

#include usingnamespacestd; constintN=1e5+10; intn; intq[N],tmp[N]; voidmerge_sort(intq[],intl,intr) { if(l>=r)return;//判斷序列中是否為空或者只有一個數字,如果是的話,我們就不用排序了 //確定分界點 intmid=l+r>>1; //遞歸處理 merge_sort(q,l,mid); merge_sort(q,mid+1,r); //定義雙指針 intk=0,i=l,j=mid+1; //歸并處理 while(i<=?mid?&&?j?<=?r) ??if(q[i]?

結果:

責任編輯:lq

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

    關注

    0

    文章

    70

    瀏覽量

    19788
  • 排序算法
    +關注

    關注

    0

    文章

    53

    瀏覽量

    10207
  • 數組
    +關注

    關注

    1

    文章

    419

    瀏覽量

    26368

原文標題:2020-1024=996:歸并排序!

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    低成本電源排序器解決方案

    絕大多數負載點DC-DC轉換器可以將上個轉換器的電源就緒輸出連接至下個轉換器的使能輸入,實現上電排序。這種方法只適合比較簡單的設計,不能滿足多數現代微處理器和DSP的要求這類器件
    的頭像 發表于 05-21 09:55 ?397次閱讀
    低成本電源<b class='flag-5'>排序</b>器解決方案

    一種基于分數階 PID 直流電機調速的 AGV 控制系統

    為設計一種低成本、抗干擾、穩定可靠的 AGV,提出一種基于磁帶導航的 AGV 系統。采用 Megawin 公司的80C51單片機為控制核心,以并排對稱設計的霍爾傳感器實現循跡和糾偏,紅外光
    發表于 03-25 15:10

    AI算法托管平臺是什么

    AI算法托管平臺是一種提供AI模型運行、管理和優化等服務的云端或邊緣計算平臺。下面,AI部落小編帶您詳細了解AI算法托管平臺。
    的頭像 發表于 03-06 10:22 ?279次閱讀

    【RA-Eco-RA2L1-48PIN-V1.0開發板試用】——PWM

    實現 示例:選擇排序(selection sort)是一種簡單直觀的排序算法,首先在未排序序列中找到最小(大)元素,存放到
    發表于 01-26 15:40

    詳解Linux sort命令之掌握排序技巧與實用案例

    在linux系統使用過程中,提供了sort排序命令,支持常用的排序功能。 常用參數 sort命令支持很多參數,常用參數如下: ? 短參數 長參數 說明 -n – number-sort 按字符串數值
    的頭像 發表于 01-09 10:10 ?802次閱讀

    TimSort:個在標準函數庫中廣泛使用的排序算法

    排序算法呢? 本文將帶你走進 TimSort,個在標準函數庫中廣泛使用的排序算法。 這個算法
    的頭像 發表于 01-03 11:42 ?469次閱讀

    【「從算法到電路—數字芯片算法的電路實現」閱讀體驗】+介紹基礎硬件算法模塊

    更大的熱情此形勢下,國內芯片設計水平必將迎來次大的升級,同時對從業者的要求也將大大提高。 算法是芯片自研的基石即了解組按照購買模塊進行組裝的方式,芯片開發工程師需要掌握的基本技能是組裝, 成系統
    發表于 11-21 17:05

    一種基于深度學習的二維拉曼光譜算法

    近日,天津大學精密儀器與光電子工程學院的光子芯片實驗室提出了一種基于深度學習的二維拉曼光譜算法,成果以“Rapid and accurate bacteria identification
    的頭像 發表于 11-07 09:08 ?639次閱讀
    <b class='flag-5'>一種</b>基于深度學習的二維拉曼光譜<b class='flag-5'>算法</b>

    dp接口的最新技術發展

    深度優先搜索(DFS)是一種基本的算法,用于遍歷或搜索樹或圖。它從個頂點開始,盡可能深地搜索樹的分支。當搜索到最深節點時,然后回溯。DFS可以用于解決許多問題,如尋找路徑、檢測循環、拓撲排序
    的頭像 發表于 10-30 13:52 ?509次閱讀

    時間復雜度為 O(n^2) 的排序算法

    , O(n2) 的排序算法可能會比 O(nlogn) 的排序算法執行效率高。不過隨著數據規模增大, O(nlogn) 的排序
    的頭像 發表于 10-19 16:31 ?1626次閱讀
    時間復雜度為 O(n^2) 的<b class='flag-5'>排序</b><b class='flag-5'>算法</b>

    TPS54120排序和跟蹤

    電子發燒友網站提供《TPS54120排序和跟蹤.pdf》資料免費下載
    發表于 10-10 10:54 ?0次下載
    TPS54120<b class='flag-5'>排序</b>和跟蹤

    數學建模(2)--TOPSIS法

    和K.Yoon于1981年首次提出,TOPSIS法根據有限個評價對象與理想化目標的接近程度進行排序的方法,是在現有的對象中進行相對優劣的評價。TOPSIS法是一種逼近于理想解的排序法,該方法只要求各效用函數具有
    發表于 09-06 16:38

    芯干線科技CEO說氮化鎵

    氮化鎵是一種由氮和鎵結合而來的化合物,其中氮在元素周期表排序第7位,鎵排序第31位,7月31日世界氮化鎵日因此得名,同時也以英文名GaN Day傳播到全球,并獲得行業廣泛認可。
    的頭像 發表于 08-21 10:03 ?988次閱讀

    飛凌OK-全志T527開發板nbench性能測試

    -計算波形級數近似的數值分析程序。 ASSIGNMENT個著名的任務分配算法。 IDEA一種比較新的分組密碼算法。 HUFFMAN哈夫曼壓縮-
    發表于 08-20 10:25

    手把手教你排序算法怎么寫

    今天以直接插入排序算法,給大家分享一下排序算法的實現思路,主要包含以下部分內容:插入排序介紹插入排序
    的頭像 發表于 06-04 08:03 ?1012次閱讀
    手把手教你<b class='flag-5'>排序</b><b class='flag-5'>算法</b>怎么寫