【寒假每日一题】DAY.6 有序序列的合并

news2025/1/17 3:02:09

牛客网例题:点我做题

描述
输入两个升序排列的序列,将两个序列合并为一个有序序列并输出。

数据范围: 
 
1 ≤ n,m ≤ 1000,序列中的值满足0≤val≤30000

输入描述:
输入包含三行,

第一行包含两个正整数n, m,用空格分隔
n表示第二行第一个升序序列中数字的个数
m表示第三行第二个升序序列中数字的个数

第二行包含n个整数,用空格分隔。

第三行包含m个整数,用空格分隔。

输出描述:
输出为一行,输出长度为n+m的升序序列,即长度为n的升序序列和长度为m的升序序列中的
元素重新进行升序序列排列合并。

示例1
输入:
5 6
1 3 7 9 22
2 8 10 17 33 44
输出:
1 2 3 7 8 9 10 17 22 33 44

思路

第一步:输入n,m、数组a和数组b,并创建升序后的数组c

第二步:可以用 i来遍历数组a,j来遍历数组b,k来遍历数组c;接下来就来比较i下标的数和j下标的数谁大谁小

如上图, 可以先拿1和2比较,由于合并后必须是升序的,所以1先放入数组c下标为0中,然后数组a的下标++继续和数组b里的元素比较。所以这是一个循环

第三步:接下来分类讨论哪个数组的元素多,则把剩下多的元素放到c即可

第五步:输出c数组

【❤️温馨提示】看一遍思路会理解更加深刻哟

第一步:输入n,m、数组a和数组b,并创建升序后的数组c

#include <stdio.h>
int main()
{
    int n,m;
    //输入n、m
    scanf("%d %d", &n, &m);
    int a[n];
    int b[m];
    int c[n + m];//合并后的升序序列
    //输入数组a
    for (int i = 0;i < n;i++)
        scanf("%d",&a[i]);
    //输入数组b
    for (int i = 0;i < m;i++)
        scanf("%d",&b[i]);

    return 0;
}

第二步:可以用 i来遍历数组a,j来遍历数组b,k来遍历数组c;接下来就来比较i下标的数和j下标的数谁大谁小。

注:i 遍历时一定要小于n,j遍历要小于m,一旦其中一个数组越界了,就把另一个数组剩余的元素直接放在数组c即可

#include <stdio.h>
int main()
{
    int n,m;
    //输入n、m
    scanf("%d %d", &n, &m);
    int a[n];
    int b[m];
    int c[n + m];//合并后的升序序列
    //输入数组a
    for (int i = 0;i < n;i++)
        scanf("%d",&a[i]);
    //输入数组b
    for (int i = 0;i < m;i++)
        scanf("%d",&b[i]);

    int i = 0; //遍历数组a
    int j = 0; //遍历数组b
    int k = 0; //遍历数组c
    while(i < n && j < m)
    {
        if (a[i] > b[j])
        {
            //把小的元素给数组c
            c[k] = b[j];
            k++; //数组c往后继续遍历
            j++; //数组b往后继续比较
        }
        else //a[i] <= a[j]
        {
            c[k] = a[i];
            k++;
            i++;
        }
    }
    return 0;
}

第三步:接下来分类讨论哪个数组的元素多,则把剩下多的元素放到c即可

上一步循环跳出,可能 i 等于n,j 等于 m

如果是i = n,说明a数组元素都遍历完了,接下来就把数组b剩下的元素依次放入数组c即可

j = m也是同样如此

#include <stdio.h>
int main()
{
    int n,m;
    //输入n、m
    scanf("%d %d", &n, &m);
    int a[n];
    int b[m];
    int c[n + m];//合并后的升序序列
    //输入数组a
    for (int i = 0;i < n;i++)
        scanf("%d",&a[i]);
    //输入数组b
    for (int i = 0;i < m;i++)
        scanf("%d",&b[i]);

    int i = 0; //遍历数组a
    int j = 0; //遍历数组b
    int k = 0; //遍历数组c
    while(i < n && j < m)
    {
        if (a[i] > b[j])
        {
            //把小的元素给数组c
            c[k] = b[j];
            k++; //数组c往后继续遍历
            j++; //数组b往后继续比较
        }
        else //a[i] <= a[j]
        {
            c[k] = a[i];
            k++;
            i++;
        }
    }
    if(i == n)
    {
        while(j < m)
        {
            c[k] = b[j];
            k++;
            j++;
        }
    }
    else //j == n
    {
        while (i < n)
        {
            c[k] = a[i];
            k++;
            i++;
        }
    }
    return 0;
}

第五步:输出数组c就完成啦

#include <stdio.h>
int main()
{
    int n,m;
    //输入n、m
    scanf("%d %d", &n, &m);
    int a[n];
    int b[m];
    int c[n + m];//合并后的升序序列
    //输入数组a
    for (int i = 0;i < n;i++)
        scanf("%d",&a[i]);
    //输入数组b
    for (int i = 0;i < m;i++)
        scanf("%d",&b[i]);

    int i = 0; //遍历数组a
    int j = 0; //遍历数组b
    int k = 0; //遍历数组c
    while(i < n && j < m)
    {
        if (a[i] > b[j])
        {
            //把小的元素给数组c
            c[k] = b[j];
            k++; //数组c往后继续遍历
            j++; //数组b往后继续比较
        }
        else //a[i] <= a[j]
        {
            c[k] = a[i];
            k++;
            i++;
        }
    }
    if(i == n)
    {
        while(j < m)
        {
            c[k] = b[j];
            k++;
            j++;
        }
    }
    else //j == n
    {
        while (i < n)
        {
            c[k] = a[i];
            k++;
            i++;
        }
    }

    //输出数组c
    for (int k = 0;k < n + m;k++)
        printf("%d ",c[k]);
    return 0;
}

最后这题也是完美AC啦 

2023年1月14日

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/162099.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

微信小程序开发起步

一、小程序与普通网页开发的区别 1&#xff09;运行环境不同。网页运行在浏览器环境中&#xff0c;小程序运行在微信环境中。 2&#xff09;API不同。由于运行环境不同&#xff0c;所以小程序中无法调用DOM和BOM的API&#xff0c;但是小程序可以调用微信环境提供的各种API&am…

zabbix的安装部署,一看就会

目录 1、系统组成 2、采集模式 3、监控类型 4、相关术语 5、安装部署 1、系统组成 2、采集模式 监控系统数据采集的工作模式可以分为 被动模式&#xff08;从服务器端到客户端采集数据&#xff0c;对应的英文单词是pull&#xff09; 主动模式 &#xff08;客户端主动上报…

java基于springboot的新生报到系统app新生报到安卓app新生入学报到小程序加论文

简介 本项目主要是新生报到系统&#xff0c;包含的新生入学流程的功能&#xff1a;新生可以在app里提交预报到日期确认报到&#xff0c;查看自己的学费缴费记录&#xff0c;更改自己的银行卡号&#xff0c;查看课表&#xff0c;查看寝室&#xff0c;查看自己的专业班级等个人信…

CubeMX配置:定时器中断及串口配置

本文通过CubeMX配置F103RCT6的定时器中断和串口。 文章目录1 引入2 配置过程2.1 配置时钟过程2.2 配置串口过程2.3 定时器中断配置3 生成工程代码4 测试串口及定时器中断周期5 总结1 引入 拿到一个STM32控制器&#xff0c;在啥也没有的情况下从零开始写软件&#xff0c;博主习…

Java K 个一组翻转链表

K 个一组翻转链表困难给你链表的头节点 head &#xff0c;每 k 个节点一组进行翻转&#xff0c;请你返回修改后的链表。k 是一个正整数&#xff0c;它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍&#xff0c;那么请将最后剩余的节点保持原有顺序。你不能只是单纯的…

电视为何降价至200元依然没人买?爱奇艺给出了答案

近日爱奇艺提高降低会员的服务内容&#xff0c;消费者要享受到将内容投放到电视就要买更贵的会员服务&#xff0c;引发热议&#xff0c;此举或许能解释国内消费者为何如今不买电视了。2022年电视行业可谓是一个相当惨淡的行业&#xff0c;量价齐跌&#xff0c;随着2022年底的到…

计算机视觉OpenCv学习系列:第二部分、图像操作

第二部分、图像操作第一节、图像读取与显示1.图像理解2.图像读取与显示3.代码练习与测试第二节、图像色彩空间转换1.图像色彩空间2.函数说明与解释3.代码练习与测试第三节、图像对象的创建与赋值1.图像对象属性2.图像对象创建与赋值3.代码练习与测试第四节、图像像素的读写操作…

SpringBoot——关于controller参数校验

参数校验主要使用两个标签Validated和Valid&#xff1b; Valid是Hibernate的注解校验&#xff0c;Validated是spring的&#xff0c;是Valid的增强&#xff1b;这两个标签也有一些不同之处&#xff0c;Valid可以标注在成员属性上也可以嵌套校验&#xff0c;而Validated不行&…

Node.js 操作MySQL数据库

在讲Node.js中引入mysql模块之前先讲一下关于MySQL数据库&#xff0c;首先是关于MySQL数据库的安装和mysql服务以及对mysql命令和可视化工具的一个基本使用&#xff1b;那么在这里已经准备好了关于MySQL数据库的内容了&#xff1a; MySQL 数据库安装详细 &#xff1a; MySQL数…

redis主从复制,一主多仆启动流程

文章目录一、安装redis二、复制修改配置文件三、添加conf配置文件四、开启主从复制五、薪火相传六、反客为主7、哨兵模式一、安装redis redis安装笔记 https://blog.csdn.net/G_GUi/article/details/128361131 二、复制修改配置文件 把redis.conf复制到一个新建文件夹里面&a…

安卓手机还有这么多神仙玩法,关键只有少数人知道

随着“智能手机”的快速更新迭代&#xff0c;手机系统逐渐融入了许多实用功能&#xff1b;今年Android手机市场竞争相当激烈&#xff0c;各大手机品牌都争先恐后地向消费者展示自己的新机型。今天我就来给大家分享几个只有安卓手机才有的隐藏黑科技功能&#xff0c;每个功能都非…

cocos creator新手教程:第003节3D模型的基本概念

3.1 计算机如何制作一个3D模型 讲述这个问题之前&#xff0c;我们先来看下现实生活中我们要做一个模型&#xff0c;应该如何做呢&#xff1f;首先我们要把模型的形状给雕刻构建出来&#xff0c;现实生活中的物体都是由分子组成的连续的表面&#xff0c;计算机是离散的无法做到这…

【jQuery】常用API——尺寸、位置操作

一、jQuery 尺寸 以上参数为空&#xff0c;则是获取相应值&#xff0c;返回的是数字型。如果参数为数字&#xff0c;则是修改相应值。参数可以不必写单位。 <style>div {width: 200px;height: 200px;background-color: pink;padding: 10px;border: 15px solid red;margin…

在Windows中安装Mysql数据库(shawn安装成功记录)

一、下载安装包 首先去官网下载mysql安装包 下载网址:https://dev.mysql.com/downloads/mysql/ 下载Windows系统版本,如下图 注意版本必须是8.xx, 5开头的版本不适合本教程   点击下载,选择自己的文件路径,C盘非C盘都可以(我没有放C盘),路径中不要出现中文…

【蓝桥杯简单篇】Python组刷题日寄Part08

刷题日记&#xff1f;刷题日寄&#xff01; 萌新备战蓝桥杯python组 &#x1f339; 发现有需要纠正的地方&#xff0c;烦请指正&#xff01; &#x1f680; 欢迎小伙伴们的三连关注&#xff01; 往期系列&#xff1a; 【蓝桥杯简单篇】Python组刷题日寄Part01 【蓝桥杯简单篇】…

SCRM开源营销平台MarketGo-创建员工活码

一、背景介绍 客户需求&#xff1a;企业在做营销活动的时候&#xff0c;会有大量的客户需要添加企业微信的联系方式。这样就有两个问题&#xff1a; 一个企业微信账号添加太多会受到企业微信的限制&#xff1b;如果有多个企业微信的账号&#xff0c;添加的客户的数量也不平均…

如何给PPT文件添加水印?

我们在制作PPT的时候&#xff0c;有时候需要在幻灯片上加入logo&#xff0c;或者特定的大小、颜色等一致的文字标题&#xff0c;而幻灯片通常都是很多页数的&#xff0c;如果一张张幻灯片来添加&#xff0c;那就很费功夫。 这种情况&#xff0c;我们就可以选择通过“幻灯片母版…

SSL/TLS协议详解 - https为什么比http更安全

概述 首先纠正一个错误&#xff0c;可能很多初学者都以为HTTPS跟HTTP一样&#xff0c;都属于应用层协议。但其实HTTPS并不是一个单独的协议。HTTPS是安全版本的HTTP&#xff0c;简单理解 HTTPS HTTP SSL/TLS&#xff0c;即HTTPS就是使用SSL/TLS协议对HTTP报文进行了加密处理…

一不小心进入“决赛圈”,没“阳过”的怎么办?

前两天看到一个央视新闻&#xff0c;说河南新冠病毒感染率接近90%&#xff0c;流行毒株是奥密克戎BA.5.2&#xff0c;数字让我挺吃惊的&#xff1a;真有这么多人感染了&#xff1f; 如果是这样&#xff0c;我就属于那幸运的10%了&#xff0c;没有经历过刀片嗓&#xff0c;水泥鼻…

机器学习--模型调参、超参数优化、网络架构搜索

目录 一、模型调参 手动调超参数 多次调参的管理 机器调参与人调参的成本比较 自动调参&#xff08;AutoML&#xff09; 总结 二、超参数优化 在搜索空间中选择超参数 HPO算法有哪些 Black-Box Multi-Fidelity 总结 三、网络架构搜索 Neural Architecture Sear…