青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

我所理解的歸并排序算法

 

作者:goal00001111(高粱)

           始發于goal00001111的專欄;允許自由轉載,但必須注明作者和出處

 

      引子:這篇文章以前寫過,最近復習排序算法,覺得以前的代碼還可以改進,因此有了此文。

      歸并排序算法以ONlogN)最壞情形運行時間運行,而所使用的比較次數幾乎是最優的。

該算法中最基本的操作是合并兩個已排序的表,這只需要線性的時間,但同時需要分配一個臨時數組來暫存數據。

歸并排序算法可以用遞歸的形式實現,形式簡潔易懂。如果N=1,則只有一個元素需要排序,我們可以什么都不做;否則,遞歸地將前半部分數據和后半部分數據各自歸并排序,然后合并這兩個部分。

歸并排序算法也可以用非遞歸的形式實現,稍微難理解一點。它剛好是遞歸分治算法的逆向思維形式,在使用遞歸分治算法時,程序員只需考慮將一個大問題分成若干個形式相同的小問題,和解的邊界條件,具體如何解決這些小問題是由計算機自動完成的;而非遞歸形式要求程序員從最基本的情況出發,即從解決小問題出發,一步步擴展到大問題。

我這里兩種形式都給出。

另外,很多人在寫遞歸形式的歸并排序算法時,臨時數組是在MergeSort函數中分配的,這使得在任一時刻都可能有logN個臨時數組處在活動期,如果數據較多,則開銷很大,實用性很差

我把臨時數組設置在Merge函數中,避免了這個問題。

///////////////////////////////////////////////////////////////////////

遞歸形式:

template <class T>

void MSort(T a[], int left, int right)

{

      if (left < right)

      {

            int center = (left + right) / 2;

            MSort(a, left, center);

            MSort(a, center+1, right);

            Merge(a, left, center+1, right+1);

      }

}

 

template <class T>

void MergeSort(T a[], int n)

{

      MSort(a, 0, n-1);

}

///////////////////////////////////////////////////////////////////////

非遞歸形式:

算法介紹:先介紹三個變量beforeLenafterLeni的作用:

int beforeLen; //合并前序列的長度

int afterLen;//合并后序列的長度,合并后序列的長度是合并前的兩倍

int i = 0;//開始合并時第一個序列的起始位置下標,每次都是從0開始

ii+beforeLeni+afterLen定義被合并的兩個序列的邊界。

算法的工作過程如下:

開始時,beforeLen被置為1i被置為0。外部for循環的循環體每執行一次,都使beforeLenafterLen加倍。內部的while循環執行序列的合并工作,它的循環體每執行一次,i都向前移動afterLen個位置。當n不是afterLen的倍數時,如果被合并序列的起始位置i,加上合并后序列的長度afterLen,超過輸入數組的邊界n,就結束內部循環;此時如果被合并序列的起始位置i,加上合并前序列的長度beforeLen,小于輸入數組的邊界n,還需要執行一次合并工作,把最后長度不足afterLen,但超過beforeLen的序列合并起來。這個工作由語句Merge(a, i, i+beforeLen, n);完成。

 

template <class T>

void MergeSort(T a[], int n)

{

      int beforeLen; //合并前序列的長度

      int afterLen = 1;//合并后序列的長度

     

      for (beforeLen=1; afterLen<n; beforeLen=afterLen)

      {

            afterLen = beforeLen << 1; //合并后序列的長度是合并前的兩倍

           

            int i = 0;//開始合并時第一個序列的起始位置下標,每次都是從0開始

            for ( ; i+afterLen<n; i+=afterLen)

                  Merge(a, i, i+beforeLen, i+afterLen);

           

            if (i+beforeLen < n)

                  Merge(a, i, i+beforeLen, n);

      }

}

///////////////////////////////////////////////////////////

      上面兩種算法都要用到下面的合并函數。

/*函數介紹:合并兩個有序的子數組

輸入:數組a[],下標leftcenter,元素個數lena[left]~a[center-1]a[center]~a[len-1]已經按非遞減順序排序。

輸出:按非遞減順序排序的子數組a[left]~a[len-1]

*/

template <class T>

void Merge(T a[], int left, int center, int len)

{

      T *t = new T[len-left];//存放被合并后的元素

      int i = left;

      int j = center;

      int k = 0;

 

      while (i<center && j<len)

      {

            if (a[i] <= a[j])

                  t[k++] = a[i++];

            else

                  t[k++] = a[j++];

      }

     

      while (i < center)

            t[k++] = a[i++];

           

      while (j < len)

            t[k++] = a[j++];

           

      //t[]的元素復制回a[]

      for (i=left,k=0; i<len; i++,k++)

            a[i] = t[k];

 

      delete []t;

}  

 

Posted on 2009-06-09 08:25 夢想飛揚 閱讀(7695) 評論(4)  編輯 收藏 引用

Feedback

# re: 我所理解的歸并排序算法(新)  回復  更多評論   

2009-06-09 11:54 by Wang Feng
void Merge(T a[], int left, int center, int len)

{

T *t = new T[len-left];//存放被合并后的元素
----------------------------------------------------------------
C++支持這樣的語法
T t[len-left];

我猜想效率會比
T *t = new T[len-left];

更高

# re: 我所理解的歸并排序算法(新)  回復  更多評論   

2009-06-09 22:01 by wzc
T t[len-left];
這是在棧空間定義的。如果是遞歸的話本來就會占用棧空間,T t[len-left]更會加劇占內存的減少,數據大的話,我猜會華麗的堆棧溢出

# re: 我所理解的歸并排序算法(新)[未登錄]  回復  更多評論   

2009-08-05 16:57 by 1
寫的很棒哦

# re: 我所理解的歸并排序算法(新)  回復  更多評論   

2009-10-20 11:06 by notme
諸多版本皆同;不知那個是源;

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲综合第一页| 欧美精品免费播放| 亚洲国产精品第一区二区| 亚洲美女网站| 伊人激情综合| 欧美在线看片| 亚洲免费一级电影| 一级成人国产| 一本色道久久综合精品竹菊| 亚洲激情电影中文字幕| 欧美大学生性色视频| 亚洲欧美国产日韩天堂区| 亚洲免费av电影| 日韩视频在线一区| 亚洲黄色一区| 亚洲三级国产| 99国产精品视频免费观看| 亚洲国产精品一区二区www在线 | 欧美日韩精品一区二区三区| 久久久久久久一区| 欧美在线观看天堂一区二区三区 | 亚洲线精品一区二区三区八戒| 久久婷婷国产麻豆91天堂| 久久成人免费视频| 噜噜噜躁狠狠躁狠狠精品视频| 蜜臀av一级做a爰片久久| 浪潮色综合久久天堂| 欧美成人一品| 美女国内精品自产拍在线播放| 欧美xart系列高清| 日韩写真视频在线观看| 亚洲一区二区精品在线| 性欧美大战久久久久久久久| 欧美一区二区三区精品电影| 亚洲国产日韩欧美在线99| 亚洲精品国久久99热| 亚洲午夜一区| 久久嫩草精品久久久久| 欧美日韩和欧美的一区二区| 国产美女高潮久久白浆| 国产欧美日韩91| 亚洲黄色免费网站| 欧美在线看片| 亚洲日本乱码在线观看| 香蕉免费一区二区三区在线观看 | 激情欧美一区二区三区在线观看| 黄色亚洲大片免费在线观看| 亚洲激情偷拍| 欧美一级视频免费在线观看| 久久综合九色综合久99| 亚洲综合社区| 国产欧美一区二区精品仙草咪| 久久亚洲午夜电影| 国产精品久久久| 亚洲狠狠丁香婷婷综合久久久| 91久久在线| 欧美一区二区三区四区在线观看 | 国产在线高清精品| 一区二区日韩免费看| 老**午夜毛片一区二区三区| 久久漫画官网| 亚洲色图自拍| 欧美黄色片免费观看| 国产日韩精品电影| 亚洲综合清纯丝袜自拍| 亚洲国产老妈| 久久久99免费视频| 国产精品国产三级国产专区53| 亚洲国产精品电影| 免费看亚洲片| 久久久久国产精品一区三寸| 国产日韩欧美一区二区三区四区| 一区二区久久久久| 亚洲区欧美区| 免费欧美视频| 亚洲激情午夜| 欧美大片免费观看| 久久久久久穴| 亚洲国产精品成人综合| 麻豆精品一区二区av白丝在线| 性欧美办公室18xxxxhd| 国产嫩草影院久久久久| 亚洲视频在线一区| 一区二区国产精品| 欧美午夜精品久久久久久孕妇| 99精品热6080yy久久 | 亚洲在线视频网站| 一本色道久久综合亚洲精品按摩 | 午夜宅男欧美| 亚洲视频一二三| 欧美日韩中文另类| 亚洲无限av看| 亚洲视频在线观看一区| 快射av在线播放一区| 国产午夜精品美女毛片视频| 久久嫩草精品久久久精品| 农村妇女精品| 亚洲色诱最新| 欧美精品导航| 伊人成综合网伊人222| 欧美韩日高清| 国产精品乱码| 欧美插天视频在线播放| 欧美日韩亚洲一区三区| 久久福利精品| 欧美欧美天天天天操| 久久精品视频va| 欧美高清在线一区二区| 欧美伊人精品成人久久综合97| 猫咪成人在线观看| 欧美一区二区三区喷汁尤物| 免费看av成人| 久久精品国产亚洲aⅴ| 欧美成人黑人xx视频免费观看| 亚洲欧美日韩国产综合在线 | 欧美一区二区三区在| 99视频一区二区三区| 久久精品视频在线| 午夜精品久久久久久久99黑人| 欧美aaa级| 久久久久国产精品一区| 欧美午夜宅男影院| 日韩亚洲欧美在线观看| 亚洲国产精品久久久久久女王| 欧美在线视频导航| 午夜精彩国产免费不卡不顿大片| 午夜精品久久久久| 欧美国产先锋| 欧美激情黄色片| 精品成人国产| 欧美一区激情| 欧美在线精品一区| 国产精品男女猛烈高潮激情| 亚洲九九爱视频| 一区二区久久久久| 欧美久久久久久| 亚洲精品社区| 一区二区电影免费观看| 欧美精品久久久久久久| 亚洲国产精品一区二区www| 在线免费观看欧美| 可以免费看不卡的av网站| 免费的成人av| 亚洲欧洲在线一区| 欧美暴力喷水在线| 亚洲人成绝费网站色www| 亚洲精品一区中文| 欧美日韩不卡一区| 一二三四社区欧美黄| 亚洲欧美成人网| 国产欧美日韩精品一区| 欧美一区2区三区4区公司二百| 久久久久国产精品一区三寸| 国内精品久久久久伊人av| 久久久久久亚洲精品杨幂换脸 | 久久久午夜精品| 尤物99国产成人精品视频| 久久亚洲精选| 日韩亚洲欧美中文三级| 亚洲欧美不卡| 一区二区三区日韩在线观看| 久久久久国产一区二区三区四区| 欧美日韩视频在线一区二区| 亚洲国产日韩精品| 亚洲精品在线二区| 欧美视频网站| 久久精品欧美日韩精品| 免费观看成人鲁鲁鲁鲁鲁视频| 亚洲激情第一区| 国产精品爱啪在线线免费观看| 亚洲制服av| 免费成人你懂的| 亚洲影院色在线观看免费| 国产欧美日本一区视频| 麻豆av福利av久久av| 91久久嫩草影院一区二区| 亚洲欧美第一页| 悠悠资源网久久精品| 国产精品h在线观看| 欧美在线播放一区| 亚洲人成网站在线播| 香蕉久久一区二区不卡无毒影院| 激情欧美一区二区| 国产精品分类| 免费av成人在线| 欧美一二三视频| 日韩亚洲欧美成人一区| 久久天堂国产精品| 亚洲综合国产精品| 亚洲精品一区二区在线| 国产一区二区高清| 国产精品v日韩精品| 男女激情视频一区| 欧美一区二视频| 亚洲无亚洲人成网站77777| 亚洲高清不卡在线| 久久夜色精品国产| 欧美在线观看视频| 午夜精品久久久久| 亚洲性图久久|