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

歸并排序算法以O(nlogn)最壞情形運行時間運行,而所使用的比較次數幾乎是最優的。它可以用遞歸的形式實現,形式簡潔易懂。但是需要注意的是當用遞歸形式時,如果數據較多,則開銷很大,實用性很差,所以我們一般采用非遞歸的形式。我這里兩種形式都給出。
      不管是遞歸還是非遞歸,歸并排序算法中基本的操作是合并兩個已經排序的數組。
遞歸形式:
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);
}
///////////////////////////////////////////////////////////////////////
非遞歸形式:
算法介紹:先介紹三個變量beforeLen,afterLen和i的作用:
int beforeLen; //合并前序列的長度
int afterLen;//合并后序列的長度,合并后序列的長度是合并前的兩倍
int i = 0;//開始合并時第一個序列的起始位置下標,每次都是從0開始
i,i+beforeLen-1,i+afterLen-1定義被合并的兩個序列的邊界。
算法的工作過程如下:
開始時,beforeLen被置為1,i被置為0。外部for循環的循環體每執行一次,都使beforeLen和afterLen加倍。內部的while循環執行序列的合并工作,他的循環體每執行一次,i都向前移動afterLen個位置。當n不是afterLen的倍數時,如果被合并序列的起始位置i,加上合并后序列的長度afterLen,超過輸入數組的邊界n,就結束內部循環;此時如果被合并序列的起始位置i,加上合并前序列的長度beforeLen,小于輸入數組的邊界n,還需要執行一次合并工作,把最后長度不足afterLen,但超過beforeLen的序列合并起來。這個工作由算法的語句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;//開始合并時第一個序列的起始位置下標,每次都是從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);
      }
}
///////////////////////////////////////////////////////////
      上面兩種算法都要用到下面的合并函數。
/*函數介紹:合并兩個有序的子數組
輸入:數組a[],下標left,center,right,元素個數n,a[left]~a[center]及a[center+1]~a[right]已經按非遞減順序排序。
輸出:按非遞減順序排序的子數組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[]的元素復制回a[]
      for (i=left,k=0; i<=right; i++,k++)
            a[i] = t[k];

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

Feedback

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

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

感覺上漏掉了某些情況

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

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

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            99精品国产热久久91蜜凸| 免费影视亚洲| 一区二区三区欧美激情| 欧美日韩蜜桃| 亚洲欧美bt| 午夜视频一区二区| 国产一区二区中文字幕免费看| 久久gogo国模裸体人体| 欧美中文字幕在线观看| 一区二区三区在线免费播放| 欧美二区在线| 欧美日韩一区二区三区在线看| 亚洲一区欧美| 欧美一区二区观看视频| 欲香欲色天天天综合和网| 亚洲国产你懂的| 欧美精品一区二区三区久久久竹菊| aaa亚洲精品一二三区| 一区二区三区四区五区视频| 国产麻豆日韩| 欧美黄色免费网站| 欧美性天天影院| 美女诱惑一区| 欧美少妇一区二区| 久久婷婷激情| 欧美视频在线观看| 久久综合中文字幕| 国产精品v欧美精品v日韩| 久久免费99精品久久久久久| 欧美激情一区二区三级高清视频| 亚洲欧美国产精品va在线观看 | 久久国产视频网站| 久久亚洲欧美| 午夜精彩视频在线观看不卡| 久久躁狠狠躁夜夜爽| 亚洲无线视频| 免费精品99久久国产综合精品| 亚洲欧美精品在线| 欧美成人首页| 玖玖精品视频| 国产麻豆9l精品三级站| 亚洲欧洲综合另类| 精品动漫3d一区二区三区免费版| 99re8这里有精品热视频免费| 精品999在线播放| 亚洲一区二区网站| 一本久久综合亚洲鲁鲁| 免费成人你懂的| 久久久国产精品亚洲一区| 国产精品xnxxcom| 亚洲人成网站999久久久综合| 国内精品美女在线观看| 亚洲午夜av| 亚洲香蕉伊综合在人在线视看| 久久综合色8888| 久久久夜夜夜| 国产午夜亚洲精品羞羞网站| 亚洲手机成人高清视频| 9久re热视频在线精品| 美女精品自拍一二三四| 麻豆精品在线观看| 好看的日韩av电影| 久久激情五月婷婷| 久久先锋影音| 精品二区视频| 久久在线观看视频| 开心色5月久久精品| 国内精品久久久久久| 午夜宅男久久久| 久久激情综合网| 国产在线国偷精品产拍免费yy| 亚洲欧美激情精品一区二区| 亚洲欧美韩国| 国产日韩欧美精品| 欧美一区二区视频97| 久久精品视频在线观看| 黄色一区三区| 久久亚洲午夜电影| 亚洲国产成人久久综合| 日韩一级精品视频在线观看| 欧美日韩亚洲高清一区二区| 一区二区三区波多野结衣在线观看| 一本综合精品| 国产精品你懂的在线欣赏| 午夜国产精品视频| 免费亚洲网站| 亚洲视频免费看| 国产欧美日韩综合精品二区| 久久精品99国产精品日本| 久久综合久久综合久久| 亚洲毛片av在线| 国产精品嫩草久久久久| 久久成人精品| 亚洲欧洲一区二区三区久久| 亚洲午夜电影网| 国产亚洲精品成人av久久ww| 理论片一区二区在线| 亚洲欧洲日产国产网站| 午夜久久福利| 亚洲高清二区| 国产精品美女久久久久久2018 | 亚洲二区视频| 亚洲一区二区三区四区中文| 国产欧美日韩精品丝袜高跟鞋| 久久久久99精品国产片| 91久久精品视频| 久久精品国产久精国产一老狼| 亚洲福利视频一区| 国产精品v亚洲精品v日韩精品| 欧美资源在线| 夜夜嗨av一区二区三区网页| 久热精品视频在线| 亚洲五月婷婷| 亚洲精品女人| 在线播放国产一区中文字幕剧情欧美| 欧美日韩成人一区| 久久全球大尺度高清视频| 在线亚洲观看| 亚洲精品视频免费观看| 久久综合狠狠综合久久激情| 亚洲一区二区欧美日韩| 一色屋精品视频在线看| 国产精品热久久久久夜色精品三区| 裸体丰满少妇做受久久99精品| 亚洲一级影院| 99成人在线| 亚洲精品欧洲精品| 欧美成人日韩| 美女图片一区二区| 久久精品视频免费播放| 亚洲欧美国产视频| 一区二区三区四区五区在线| 亚洲国产婷婷| 曰韩精品一区二区| 韩国av一区二区三区在线观看| 国产精品日日做人人爱| 欧美日韩在线精品| 欧美精品色网| 欧美日韩 国产精品| 免费观看在线综合| 模特精品裸拍一区| 久久尤物电影视频在线观看| 欧美在线综合视频| 欧美在线影院在线视频| 欧美一区午夜视频在线观看| 午夜日韩激情| 欧美在线日韩精品| 久久九九电影| 另类亚洲自拍| 欧美极品一区二区三区| 欧美高清视频一区二区| 欧美国产精品久久| 欧美极品在线播放| 欧美日韩一区二区三区在线看 | 国产伦精品一区二区三区免费迷 | 亚洲人成毛片在线播放| 亚洲国产精品va在线看黑人动漫| 黄色在线一区| 亚洲欧洲日本专区| 亚洲精品一区中文| 亚洲一区二区三区免费视频 | 在线观看日产精品| 亚洲国产精品久久| 一区二区三区欧美视频| 午夜国产精品视频| 欧美制服丝袜| 欧美v日韩v国产v| 亚洲欧洲在线视频| 亚洲免费网址| 葵司免费一区二区三区四区五区| 欧美www在线| 国产精品v日韩精品| 国产一区二区日韩精品| 亚洲激情视频在线| 亚洲午夜女主播在线直播| 久久国产欧美| 亚洲人www| 亚洲女性喷水在线观看一区| 久久久久99| 欧美日韩在线观看一区二区三区| 国产欧美日韩视频一区二区三区| 亚洲第一网站免费视频| 中国成人在线视频| 免费欧美高清视频| 亚洲小说春色综合另类电影| 久久久精品动漫| 国产精品久久97| 亚洲精品女av网站| 久久精品视频网| 洋洋av久久久久久久一区| 久久国产欧美精品| 欧美视频亚洲视频| 亚洲国产日韩欧美| 久久九九电影| 在线亚洲电影| 欧美日韩国产在线播放| 在线欧美日韩国产| 久久久高清一区二区三区| 中文网丁香综合网| 欧美好吊妞视频|