C语言-合并法排序

C语言算法-07-合并法排序

1.解题思路

合并法排序(将两个有序数组A、B合并成另一个有序的数组c,升序)
基本思想:
1)先在A、B数组中各取第一个元素进行比较,将小的元素放入c数组;
2)取小的元素所在数组的下一个元素与另一数组中上次比较后较大的元素比较,
重复上述比较过程,直到某个数组被先排完;
3)将另一个数组剩余元素抄入C数组,合并排序完成。

2.C语言代码
#include "stdio.h"

int main(){
    // 初始化数组与变量
    int a[10] = {1,3,5,7,9,10,11,13,14,20};
    int b[10] = {2,4,6,8,9,11,13,16,17,19};
    int c[20];
    int i,ia=0,ib=0,ic=0;

    // 排序过程
    while (ia < 10 && ib < 10){
        if (a[ia] < b[ib]){
            c[ic] = a[ia];
            ia++;
        } else{
            c[ic] = b[ib];
            ib++;
        }
        ic++;
    }

    // 将a数组剩下的元素添加到c数组
    while (ia <= 9){
        c[ic] = a[ia];
        ia++;
        ic++;
    }

    // 将b数组剩下的元素添加到c数组
    while (ib <= 9){
        c[ic] = b[ib];
        ib++;
        ic++;
    }

    // 打印输出
    for(i=0; i < 20; i++)
        printf("%3d", c[i]);
    printf("\n");
}
  • 5
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值