结构体归并排序c语言,数据结构之---C语言实现归并排序

//归并排序

//杨鑫

#include

#include

#define MAXN 1000

int N, i;

int a[MAXN];

void merge(int a[], int p, int q, int r)

{

int i, j, k, n1, n2;

int *front, *back;

n1 = q - p + 1; //前一部分的长度

n2 = r-q; //后一部分的长度

front = (int *) malloc (n1 * sizeof(int));

back = (int *) malloc (n2 * sizeof(int));

for(i = 0; i < n1; i++)

front[i] = a[p + i];

for(i = 0; i < n2; i++)

back[i] = a[q + 1 + i];

//合并元素

i = 0, j = 0, k= p;

while(i < n1 && j < n2)

{

if(front[i] < back[j])

{

a[k++] = front[i++];

}

else

{

a[k++] = back[j++];

}

}

//将剩余的元素合并

while(i < n1)

{

a[k++] = front[i++];

}

while(j < n2)

{

a[k++] = back[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);

}

}

int main()

{

printf("===================归并排序=============\n\n");

printf("请输入将要排序元素的个数!\n");

scanf("%d", &N);

printf("请分别输入 %d 个元素\n", N);

for(i=0; i < N; i++)

{

scanf("%d", &a[i]);

}

merge_sort(a, 0, N-1);

printf("\n排序后的元素是:\n");

for(i = 0; i < N; i++)

printf(" %d", a[i]);

return 0;

}

5ebaf760456c71f1dbb69b73a8ee6f22.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值