题解 | #有序序列合并#

有序序列合并

https://www.nowcoder.com/practice/a9e943b0dab142759807d0cfb6863897

#include <stdio.h>

int main() {
    int n = 0, m = 0;
    scanf("%d%d", &n, &m);
    int arr1[n];
    int arr2[m];
    int arr3[m + n]; //定义变长数组

    int i = 0;
    for (i = 0; i < n; i++) { //初始化数组arr1
        scanf("%d", &arr1[i]);
    }
    for (i = 0; i < m; i++) { //初始化数组arr2
        scanf("%d", &arr2[i]);
    }

    for (i = 0; i < n; i++) { //把arr1中的n个元素传递给arr3
        arr3[i] = arr1[i];
    }
    for (i = n; i < m + n; i++) { //把arr2中的m个元素传递给arr3
        arr3[i] = arr2[i - n];
    }

    //对arr3[m+n]进行冒泡排序完成升序排列
    int j = 0;
    for (i = 0; i < m + n - 1; i++) { //共进行m+n-1轮冒泡排序
        for (j = 0; j < m + n - 1;
                j++) { //每轮冒牌排序进行m+n-1次相邻元素大小比较
            int tem = 0;
            if (arr3[j] > arr3[j + 1]) {
                tem = arr3[j];
                arr3[j] = arr3[j + 1];
                arr3[j + 1] = tem;
            }
        }
    }

    for (i = 0; i < m + n; i++) {
        printf("%d ", arr3[i]);
    }

    return 0;
}

全部评论

相关推荐

兄弟们,实习都是在接各种api,该怎么包装简历
仁者伍敌:感觉我自己做小项目也是各种api啊,我要怎么包装简历
点赞 评论 收藏
分享
05-20 13:59
门头沟学院 Java
米黑子米黑子:你这个成绩不争取下保研?
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
今天 11:35
程序员小白条:话太多,没实力和学历,差不多回答回答就行了,身份地位不一样
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务