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

歸并排序算法以O(shè)(nlogn)最壞情形運(yùn)行時(shí)間運(yùn)行,而所使用的比較次數(shù)幾乎是最優(yōu)的。它可以用遞歸的形式實(shí)現(xiàn),形式簡潔易懂。但是需要注意的是當(dāng)用遞歸形式時(shí),如果數(shù)據(jù)較多,則開銷很大,實(shí)用性很差,所以我們一般采用非遞歸的形式。我這里兩種形式都給出。
      不管是遞歸還是非遞歸,歸并排序算法中基本的操作是合并兩個(gè)已經(jīng)排序的數(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, right, right-left+1);
      }
}

template <class T>
void MergeSort(T a[], int n)
{
      MSort(a, 0, n-1);
}
///////////////////////////////////////////////////////////////////////
非遞歸形式:
算法介紹:先介紹三個(gè)變量beforeLen,afterLen和i的作用:
int beforeLen; //合并前序列的長度
int afterLen;//合并后序列的長度,合并后序列的長度是合并前的兩倍
int i = 0;//開始合并時(shí)第一個(gè)序列的起始位置下標(biāo),每次都是從0開始
i,i+beforeLen-1,i+afterLen-1定義被合并的兩個(gè)序列的邊界。
算法的工作過程如下:
開始時(shí),beforeLen被置為1,i被置為0。外部for循環(huán)的循環(huán)體每執(zhí)行一次,都使beforeLen和afterLen加倍。內(nèi)部的while循環(huán)執(zhí)行序列的合并工作,他的循環(huán)體每執(zhí)行一次,i都向前移動(dòng)afterLen個(gè)位置。當(dāng)n不是afterLen的倍數(shù)時(shí),如果被合并序列的起始位置i,加上合并后序列的長度afterLen,超過輸入數(shù)組的邊界n,就結(jié)束內(nèi)部循環(huán);此時(shí)如果被合并序列的起始位置i,加上合并前序列的長度beforeLen,小于輸入數(shù)組的邊界n,還需要執(zhí)行一次合并工作,把最后長度不足afterLen,但超過beforeLen的序列合并起來。這個(gè)工作由算法的語句Merge(a, i, i+beforeLen-1, n-1, n);完成。

template <class T>
void MergeSort(T a[], int n)
{
      int beforeLen; //合并前序列的長度
      int afterLen = 1;//合并后序列的長度
      
      for (beforeLen=1; afterLen<n; beforeLen=afterLen)
      {
            int i = 0;//開始合并時(shí)第一個(gè)序列的起始位置下標(biāo),每次都是從0開始
            afterLen = 2 * beforeLen; //合并后序列的長度是合并前的兩倍
            
            while (i+afterLen < n)
            {
                  Merge(a, i, i+beforeLen-1, i+afterLen-1, afterLen);
                  i += afterLen;
            }
            
            if (i+beforeLen < n)
                  Merge(a, i, i+beforeLen-1, n-1, n);
      }
}
///////////////////////////////////////////////////////////
      上面兩種算法都要用到下面的合并函數(shù)。
/*函數(shù)介紹:合并兩個(gè)有序的子數(shù)組
輸入:數(shù)組a[],下標(biāo)left,center,right,元素個(gè)數(shù)n,a[left]~a[center]及a[center+1]~a[right]已經(jīng)按非遞減順序排序。
輸出:按非遞減順序排序的子數(shù)組a[left]~a[right]。
*/
template <class T>
void Merge(T a[], int left, int center, int right, int n)
{
      T *t = new T[n];//存放被排序的元素
      int i = left;
      int j = center + 1;
      int k = 0;

      while (i<=center && j<=right)
      {
            if (a[i] <= a[j])
                  t[k++] = a[i++];
            else
                  t[k++] = a[j++];
      }

      if (i == center+1)
      {
            while (j <= right)
                  t[k++] = a[j++];
      }
      else
      {
            while (i <= center)
                  t[k++] = a[i++];
      }
      //把t[]的元素復(fù)制回a[]
      for (i=left,k=0; i<=right; i++,k++)
            a[i] = t[k];

      delete []t;
}
Posted on 2006-06-15 23:24 夢想飛揚(yáng) 閱讀(1747) 評論(2)  編輯 收藏 引用

Feedback

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

2008-04-16 17:14 by indigio
if (i+beforeLen < n)
Merge(a, i, i+beforeLen-1, n-1, n);

感覺上漏掉了某些情況

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

2008-06-30 23:21 by delacroix
對啊,是不是漏掉了當(dāng)log(n)不為整數(shù)(底數(shù)為2)時(shí)的情況?

只有注冊用戶登錄后才能發(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>
            亚洲一区中文| 久久久777| 国产精品丝袜91| 亚洲欧美视频一区| 亚洲欧美日韩中文播放| 国产欧美一区二区色老头| 久久国产主播精品| 久久精品国产欧美亚洲人人爽| 韩国久久久久| 欧美国产日韩二区| 欧美精品在线免费观看| 亚洲欧美激情一区| 久久高清福利视频| 日韩视频在线观看免费| 中文国产一区| 国产一区二区三区免费在线观看| 久久久人成影片一区二区三区| 久久久久久久激情视频| 99v久久综合狠狠综合久久| 亚洲精品欧美精品| 国产日韩欧美日韩| 欧美韩日视频| 国产精品美女一区二区| 玖玖精品视频| 欧美午夜激情小视频| 久久激情视频久久| 欧美成人嫩草网站| 午夜久久久久久| 久久综合给合| 午夜视频在线观看一区二区| 久久久久国产精品厨房| 亚洲一区二区三区涩| 欧美在线亚洲在线| 亚洲视频网站在线观看| 欧美在线视频播放| 亚洲深夜福利| 久久综合久久综合久久| 亚洲综合日本| 欧美大尺度在线| 久久亚洲高清| 国产精品视频内| 亚洲电影有码| 激情亚洲成人| 亚洲欧美综合| 亚洲自拍偷拍福利| 欧美韩日精品| 欧美激情日韩| 一区二区在线观看视频在线观看| 一区二区三区av| 亚洲国产婷婷| 久久久久在线| 久久精品一区蜜桃臀影院| 欧美日韩在线亚洲一区蜜芽| 欧美大片国产精品| 国内精品视频在线观看| 亚洲男人第一网站| 亚洲欧美成人一区二区在线电影| 欧美精品福利视频| 欧美jizz19性欧美| 一区二区亚洲| 久久精品国产在热久久| 性色一区二区| 国产日韩精品入口| 午夜老司机精品| 久久激情久久| 国产专区欧美专区| 久久精品官网| 免费看精品久久片| 在线电影欧美日韩一区二区私密| 欧美影院一区| 久久精品夜色噜噜亚洲a∨| 国产日产精品一区二区三区四区的观看方式 | 一本色道久久综合亚洲精品小说 | 久久免费视频这里只有精品| 国产精品久久国产愉拍| 一区二区欧美日韩视频| 亚洲一级在线| 国产精品久久久久久亚洲调教| 99精品欧美一区二区三区综合在线 | 欧美日韩综合不卡| 一区二区三区福利| 午夜日韩视频| 狠狠综合久久av一区二区老牛| 久久精品99国产精品日本 | 亚洲精品乱码久久久久久日本蜜臀 | 国产精品二区二区三区| 亚洲视频1区2区| 午夜精品久久久久久久99黑人| 国产精品久久久久久久久久久久久| 在线亚洲精品| 欧美中文字幕| 亚洲电影下载| 欧美日韩高清一区| 亚洲综合视频1区| 久久伊人免费视频| 亚洲精品国产系列| 国产精品高潮呻吟| 久久精品国产77777蜜臀| 欧美成人精品在线视频| 一区二区高清视频| 国产午夜久久| 欧美精品激情在线| 亚洲欧美日韩第一区| 麻豆久久精品| 亚洲一区二区欧美日韩| 国产一区二区三区丝袜| 欧美国产免费| 欧美中文在线观看国产| 亚洲欧洲精品一区二区| 欧美一二三区精品| 亚洲精品免费观看| 国产深夜精品| 欧美日韩国产免费观看| 欧美怡红院视频一区二区三区| 亚洲国产精品一区二区www在线 | 怡红院精品视频| 欧美区高清在线| 久久久久久一区二区| 一区二区三区国产在线| 欧美69wwwcom| 久久久久久**毛片大全| 亚洲特级毛片| 91久久精品美女| 黑人巨大精品欧美黑白配亚洲| 欧美日韩一二区| 另类国产ts人妖高潮视频| 在线一区观看| 亚洲日产国产精品| 欧美成人午夜免费视在线看片| 午夜精品久久99蜜桃的功能介绍| 亚洲精品一区中文| 亚洲大片一区二区三区| 国语自产精品视频在线看| 国产精品免费福利| 欧美视频精品在线| 欧美激情一区在线观看| 免费成人毛片| 你懂的亚洲视频| 麻豆久久精品| 免费久久99精品国产自| 久久精品人人做人人爽| 小黄鸭视频精品导航| 亚洲在线视频| 亚洲欧美日韩综合aⅴ视频| 在线亚洲精品| 亚洲免费在线观看视频| 亚洲一区二区在线观看视频| 一区二区电影免费观看| 日韩网站在线看片你懂的| 亚洲人成久久| 夜夜嗨av一区二区三区四区| 亚洲精品视频一区| 亚洲精品日韩激情在线电影| 亚洲人成亚洲人成在线观看| 亚洲国产欧美一区二区三区同亚洲 | 久久免费偷拍视频| 久久青青草综合| 快she精品国产999| 欧美www在线| 91久久精品日日躁夜夜躁国产| 亚洲国产高清在线| 亚洲精品一二区| 亚洲综合视频一区| 欧美专区在线观看| 美女视频黄 久久| 欧美人与性禽动交情品| 国产精品国产三级国产a| 国产精品一区=区| 精久久久久久久久久久| 亚洲欧洲日本专区| 亚洲深夜福利视频| 久久国产精品一区二区三区四区 | 麻豆freexxxx性91精品| 欧美国产第二页| 在线视频精品一区| 午夜在线一区| 欧美韩国日本一区| 国产精品揄拍500视频| 伊人天天综合| 亚洲一区综合| 免费看精品久久片| 一区二区三区精品在线 | 免费亚洲电影在线观看| 亚洲精品色图| 久久精品国产欧美激情| 欧美日韩国产黄| 黑丝一区二区| 亚洲专区在线视频| 欧美成年人视频网站欧美| 亚洲少妇中出一区| 蜜乳av另类精品一区二区| 国产精品看片你懂得| 亚洲激情网站免费观看| 午夜视频在线观看一区二区| 欧美激情综合| 欧美一二三视频| 欧美三级午夜理伦三级中视频| 国内精品模特av私拍在线观看 | 国产精品一区二区久久久久| 最新国产の精品合集bt伙计|