/*************************************
分治策略:将原问题划分成n个规模较小而结构与原问题相似的子问题;
递归地解决这些子问题,然后再合并其结果,得到原问题的解。
分治模式三部曲:分解、解决、合并。
合并排序伪代码(使用哨兵):
merge(A,p,q,r):
n1 <—— q-p+1
n2 <—— r-q
create array L[0,n1] and R[0,n2]
for i <—— 0 to n1-1
do L[i] <—— A[p+i]
for j <—— 0 to n2-1
do R[j] <—— A[q+j+1]
L[n1] <—— +∞
R[n2] <—— +∞
i <—— 0
j <—— 0
for k i <—— p to r
do if L[i]<=R[j]
then A[k] <—— L[i]
i <—— i+1
else A[k] <—— R[j]
j <—— j+1
//通过调用merge完成排序:
merge_sort(A,p,r):
if p<r
then q <—— [(p+r)/2] //向下取整
merge_sort(A,p,q) //分治
merge_sort(A,q+1,r)
merge(A,p,q,r) //合并结果
**************************************/
#include <stdio.h>
#include <stdlib.h>
#define MAX_INT ~(1<<31)//最大整数
//arr[p,q] arr[q+1,r]
void merge(int *arr,int p,int q,int r)
{
if(arr==NULL)
return;
int n1=q-p+1;
int n2=r-q;
int *L=(int*)malloc((n1+1)*sizeof(int));
int *R=(int*)malloc((n2+1)*sizeof(int));
int i,j;
for(i=0;i<n1;++i)
L[i]=arr[p+i];
for(j=0;j<n2;++j)
R[j]=arr[q+j+1];
L[n1]=MAX_INT;
R[n2]=MAX_INT;
int k;
i=0,j=0;
for(k=p;k<=r;++k){
if(L[i]<=R[j])
arr[k]=L[i++];
else
arr[k]=R[j++];
}
if(L)
free(L);
if(R)
free(R);
}
void merge_sort(int *arr,int p,int r)
{
if(p<r){
int q=(r+p)/2;
merge_sort(arr,p,q);
merge_sort(arr,q+1,r);
merge(arr,p,q,r);
}
}
int main()
{
int arr[10]={4,3,5,7,1,9,12,2,0,16};
merge_sort(arr,0,9);
int i;
for(i=0;i<10;++i)
printf("%d ",arr[i]);
}
(二)合并排序
最新推荐文章于 2022-06-10 01:27:10 发布