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

我所理解的歸并排序算法

 

作者:goal00001111(高粱)

           始發(fā)于goal00001111的專欄;允許自由轉(zhuǎn)載,但必須注明作者和出處

 

      引子:這篇文章以前寫過,最近復(fù)習(xí)排序算法,覺得以前的代碼還可以改進(jìn),因此有了此文。

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

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

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

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

我這里兩種形式都給出。

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

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

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

遞歸形式:

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;//開始合并時第一個序列的起始位置下標(biāo),每次都是從0開始

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

算法的工作過程如下:

開始時,beforeLen被置為1i被置為0。外部for循環(huán)的循環(huán)體每執(zhí)行一次,都使beforeLenafterLen加倍。內(nèi)部的while循環(huán)執(zhí)行序列的合并工作,它的循環(huán)體每執(zhí)行一次,i都向前移動afterLen個位置。當(dāng)n不是afterLen的倍數(shù)時,如果被合并序列的起始位置i,加上合并后序列的長度afterLen,超過輸入數(shù)組的邊界n,就結(jié)束內(nèi)部循環(huán);此時如果被合并序列的起始位置i,加上合并前序列的長度beforeLen,小于輸入數(shù)組的邊界n,還需要執(zhí)行一次合并工作,把最后長度不足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;//開始合并時第一個序列的起始位置下標(biāo),每次都是從0開始

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

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

           

            if (i+beforeLen < n)

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

      }

}

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

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

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

輸入:數(shù)組a[],下標(biāo)leftcenter,元素個數(shù)lena[left]~a[center-1]a[center]~a[len-1]已經(jīng)按非遞減順序排序。

輸出:按非遞減順序排序的子數(shù)組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[]的元素復(fù)制回a[]

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

            a[i] = t[k];

 

      delete []t;

}  

 

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

Feedback

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

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: 我所理解的歸并排序算法(新)  回復(fù)  更多評論   

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

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

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

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

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

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   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>
            亚洲国产成人精品久久久国产成人一区| 开元免费观看欧美电视剧网站| 曰韩精品一区二区| 国产精品亚洲视频| 国产美女精品免费电影| 国产精品久久二区二区| 国产伪娘ts一区| 国产原创一区二区| 亚洲人体1000| 亚洲天堂av综合网| 久久国产福利| 欧美国产成人精品| 99视频精品在线| 欧美在线播放视频| 欧美国产一区二区在线观看 | 欧美午夜电影完整版| 国产精品免费小视频| 狠狠综合久久av一区二区小说 | 欧美夫妇交换俱乐部在线观看| 亚洲国产精品一区二区第四页av | 国产视频一区免费看| 永久免费精品影视网站| 亚洲老板91色精品久久| 久久国产精品久久久久久| 欧美激情精品久久久久久| 一区二区免费在线观看| 久久―日本道色综合久久| 欧美色另类天堂2015| 亚洲观看高清完整版在线观看| 亚洲女同性videos| 国产麻豆精品视频| 91久久国产综合久久蜜月精品 | 欧美二区乱c少妇| 亚洲五月婷婷| 欧美黄色成人网| 国产综合久久久久影院| 亚洲午夜一区二区| 亚洲电影欧美电影有声小说| 欧美一级淫片播放口| 欧美日韩视频在线一区二区观看视频| 狠狠色噜噜狠狠色综合久| 亚洲一区二区精品在线| 亚洲国产日韩欧美一区二区三区| 欧美一区综合| 国产欧美视频一区二区三区| 午夜国产精品影院在线观看| 亚洲精品国精品久久99热一| 久久青草久久| 狠狠色伊人亚洲综合成人| 欧美一区激情视频在线观看| 一区二区三区导航| 欧美日韩一区二区三区在线看| 亚洲经典在线| 欧美搞黄网站| 另类人畜视频在线| 永久免费视频成人| 美女成人午夜| 久久久天天操| 亚洲国产精品成人一区二区| 欧美 日韩 国产在线| 久久久噜噜噜久久狠狠50岁| 激情婷婷久久| 欧美国产欧美综合| 欧美黑人多人双交| 亚洲午夜电影| 亚洲综合欧美| 国产欧美一区二区三区久久人妖| 欧美亚洲在线| 久久成人羞羞网站| 在线观看日产精品| 欧美成人综合在线| 欧美精品福利视频| 亚洲私人黄色宅男| 午夜国产精品视频| 国精产品99永久一区一区| 免费不卡中文字幕视频| 欧美成人国产| 亚洲无亚洲人成网站77777| 亚洲一区二区高清视频| 国产亚洲精品一区二区| 久久久免费精品视频| 老司机免费视频一区二区三区| 亚洲七七久久综合桃花剧情介绍| 亚洲片区在线| 国产精品一区二区在线观看| 久久婷婷麻豆| 欧美精品一区三区| 国产麻豆综合| 久久偷看各类wc女厕嘘嘘偷窃| 久久久蜜桃一区二区人| 日韩亚洲欧美一区| 亚洲欧美日韩国产一区二区三区| 在线观看视频一区二区| 亚洲免费大片| 黑人一区二区三区四区五区| 亚洲品质自拍| 精品动漫3d一区二区三区免费| 亚洲精品乱码视频| 国产主播一区二区三区| 亚洲黄色一区| 国产欧美日韩激情| 亚洲激情视频| 国内偷自视频区视频综合| 亚洲国产婷婷香蕉久久久久久| 国产精品一区二区三区观看| 亚洲日本va在线观看| 国外视频精品毛片| 亚洲私人影院| 夜夜夜久久久| 久久国产精品第一页| 一区二区三区四区在线| 久久视频在线视频| 欧美一区二区高清| 欧美日韩不卡合集视频| 欧美成人精品一区二区| 国产欧美一区二区三区久久人妖| 亚洲免费观看在线观看| 影音先锋日韩精品| 欧美一区二区三区电影在线观看| 亚洲婷婷综合色高清在线| 欧美xx视频| 欧美福利小视频| 经典三级久久| 久久久久九九视频| 久久综合伊人77777蜜臀| 国产区在线观看成人精品| 亚洲图中文字幕| 亚洲欧美在线视频观看| 欧美午夜在线| 一区二区三区四区五区精品视频| 9人人澡人人爽人人精品| 免费观看成人| 亚洲盗摄视频| 亚洲精品一二三| 欧美国产欧美亚洲国产日韩mv天天看完整 | 老司机精品久久| 国产日韩精品电影| 亚洲自拍偷拍麻豆| 欧美一区二区成人| 国产精品一区一区| 午夜精品剧场| 久久久蜜臀国产一区二区| 国内激情久久| 久久永久免费| 欧美激情一区三区| 亚洲精品美女久久久久| 欧美精品国产一区二区| 亚洲美女中文字幕| 午夜亚洲性色视频| 国产真实乱偷精品视频免| 久久噜噜噜精品国产亚洲综合| 欧美福利在线观看| 99精品热视频只有精品10| 亚洲视频自拍偷拍| 午夜宅男欧美| 狠狠色狠色综合曰曰| 免费在线观看日韩欧美| 欧美v国产在线一区二区三区| 亚洲日本在线观看| 国产精品xxxav免费视频| 亚洲欧美日韩综合| 欧美88av| 亚洲欧美日韩中文视频| 激情欧美一区二区三区| 欧美精品v日韩精品v韩国精品v | 亚洲国产美女久久久久| 国产精品99久久久久久久女警| 国产精品高清在线观看| 久久精品道一区二区三区| 亚洲国产日韩欧美在线99| 午夜欧美大片免费观看| 在线成人激情| 欧美性猛交xxxx免费看久久久| 久久成人在线| 夜夜狂射影院欧美极品| 久久噜噜亚洲综合| 日韩视频在线观看| 国产亚洲高清视频| 欧美日韩国产不卡| 久久久91精品国产一区二区三区 | 另类亚洲自拍| 亚洲欧美三级伦理| 亚洲国产精品一区二区第四页av| 欧美一区二区三区免费观看视频| 亚洲风情在线资源站| 国产精品久久一级| 欧美va天堂在线| 校园激情久久| 亚洲视频www| 亚洲精品国产精品久久清纯直播| 久久久国产精品一区二区中文| 中国成人黄色视屏| 亚洲国产成人久久综合一区| 国产午夜精品视频免费不卡69堂| 欧美日韩亚洲成人| 欧美高清在线精品一区| 久久亚洲精品网站| 久久国内精品自在自线400部| 亚洲一区免费看| 一本一本久久a久久精品综合妖精|