歸並排序
歸並排序有兩種實現方法
(
自底向上的基本思想是
n為偶數
data:image/s3,"s3://crabby-images/ba119/ba119d45d63e37a18ca8a214e6b69fb9ea9d6486" alt=""
參與歸並)
data:image/s3,"s3://crabby-images/66606/666066c683e866ab69c47f0c28b5ae7a7d07eed6" alt=""
後一個子文件長度仍為
data:image/s3,"s3://crabby-images/f8d4b/f8d4b8ec61f1ce22be5048efbef21061436ec122" alt=""
序的子文件兩兩歸並
上述的每次歸並操作
(
【 參見動畫演示 】
(
分析
在某趟歸並中
data:image/s3,"s3://crabby-images/ea92f/ea92f42a63fbdc2787e4ec295d8fd1c78a808367" alt=""
子文件
[
data:image/s3,"s3://crabby-images/e7b78/e7b78f69d20ae27e024f8b4f15beb9f20585fc74" alt=""
注意
調用歸並操作將相鄰的一對子文件進行歸並時
情況進行特殊處理
① 若子文件個數為奇數
② 若子文件個數為偶數
具體算法如下
void MergePass(SeqList R
{ //對R[
int i;
for(i=
Merge(R
//歸並長度為length的兩個相鄰子文件
if(i+length Merge(R,i,i+length-1,n); //歸並最後兩個子文件 //注意:若i≤n且i+length-1≥n時,則剩余一個子文件輪空,無須歸並 } //MergePass (4)二路歸並排序算法 void MergeSort(SeqList R) {//采用自底向上的方法,對R[1..n]進行二路歸並排序 int length; for(1ength=1;length MergePass(R,length); //有序段長度≥n時終止 } 注意: 自底向上的歸並排序算法雖然效率較高,但可讀性較差。tW.WiNgWit.cOM
From:http://tw.wingwit.com/Article/program/sjjg/201311/23777.html