实验4二分归并排序

Posted zhang-kelly

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实验4二分归并排序相关的知识,希望对你有一定的参考价值。

问题:

对n个不同的数构成的数组A[1..n]进行排序,其中n=2^k.

解析:

根据分治的思想,对于每一个待排序的数组,拆分成左右两端,分别对左右两段进行排序,对于已经有序的两个数组把他们合并起来。

设计(核心代码):

 1 void merge(int low,int mid,int high)
 2 {
 3     int i=low,j=mid+1,k=low;
 4     while(i<=mid&&j<=high)
 5         if(s1[i]<s1[j])
 6             s2[k++]=s1[i++];
 7         else
 8             s2[k++]=s1[j++];
 9     while(i<=mid)
10         s2[k++]=s1[i++];
11     while (j<=high)
12         s2[k++]=s1[j++];
13     for ( i = low; i <=high ; i++) 
14     {
15         s1[i]=s2[i];
16         cout<<s1[i];
17     }
18     cout<<endl;
19 }
20  
21 void mergeSort(int a, int b)
22 {
23     if(a<b)
24     {
25         int mid=(a+b)/2;
26         mergeSort(a,mid);
27         mergeSort(mid+1,b);
28         merge(a,mid,b);
29     }
30 }

分析:

数组拆分的复杂度是O( log(n) ),合并数组的复杂度是O(n),总的复杂度是O( nlog(n) )。

源码:

https://github.com/Big-Kelly/Algorithm

技术图片
 1 #include <iostream>
 2 using namespace std;
 3 const int MAX=100;
 4 int s1[MAX],s2[MAX];
 5 void merge(int low,int mid,int high)
 6 {
 7     int i=low,j=mid+1,k=low;
 8     while(i<=mid&&j<=high)
 9         if(s1[i]<s1[j])
10             s2[k++]=s1[i++];
11         else
12             s2[k++]=s1[j++];
13     while(i<=mid)
14         s2[k++]=s1[i++];
15     while (j<=high)
16         s2[k++]=s1[j++];
17     for ( i = low; i <=high ; i++) 
18     {
19         s1[i]=s2[i];
20         cout<<s1[i];
21     }
22     cout<<endl;
23 }
24  
25 void mergeSort(int a, int b)
26 {
27     if(a<b)
28     {
29         int mid=(a+b)/2;
30         mergeSort(a,mid);
31         mergeSort(mid+1,b);
32         merge(a,mid,b);
33     }
34 }
View Code

 

以上是关于实验4二分归并排序的主要内容,如果未能解决你的问题,请参考以下文章

归并排序

基本排序之归并排序

php常用的排序算法与二分法查找

排序算法——归并排序

分治算法 ------二分归并排序

归并排序:小和问题