sort_merge 合并排序

网上看到的sort_merge排序算法,此算法没有free,不过也可以参考学习。

#include<stdio.h>

#include<stdlib.h>
#include<time.h>
#define random(i) (rand()%i)
#define N 12
#define INFINITY 99999999

//要排序的数存放在a数组汇总,p,q,r是数组下标
void Merge(int *a,int p,int q,int r)
{ int n1=q-p+1;
  int n2=r-q;
  int *L=(int *)malloc(sizeof(int)*n1);
  int *R=(int *)malloc(sizeof(int)*n2);
  int i,j,k;
  int m=0;
  if (L==NULL)
   {  
      printf("申请空间失败\n");
    }
   if (R==NULL)
    {
       printf("空间申请失败\n");
    }
    for (i=0;i<n1;i++)
     {
       L[i++]=a[p+i];
        i--;
    }
    for (j=0;j<n2;j++)
    {
       R[j++]=a[q+j+1];
       j--;
    }
    L[n1]=INFINITY;
    R[n2]=INFINITY;
    i=0;
    j=0;

    for(k=p;k<=r;k++)
     {
       if(L[i]<=R[j])
        {
          a[k]=L[i];
          i++;
        }
        else
        {
           a[k]=R[j];
            j++;
        }
     }
}
void  merge_sort(int *A,int p,int r)
{
  int q;
  if(p<r)
    {
      q=(p+r)/2;
       merge_sort(A,p,q);
       merge_sort(A,q+1,r);
       Merge(A,p,q,r);
     }
}

void main()
{
  int rand_no=0;
  int i=0;
  int j=0;
  int a[N];  // n表示数组长度
  srand((int)time(0));  // 设置随机数种子
  printf("===============排序前================");
  printf ("\n");
  for (rand_no=0;rand_no<N;rand_no++)
   {
      a[rand_no]=random(100);
      printf("%5d",a[rand_no]);
   }
   printf("\n");
   merge_sort(a,0,N);
   printf("=============排序后===============");
   printf("\n");
     for(i=1;i<=N;i++)
       printf("%5d",a[i]);
       printf("\n");

}


from  oschina.com

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值