2023 年 5 月青少年软编等考 C 语言一级真题解析

文章概述了C语言中的几个基础编程题目,涉及输入输出操作、整数计算、大写字母判断、数的累加以及金币发放问题的解决,通过实际例子展示了如何使用循环结构实现这些功能。
摘要由CSDN通过智能技术生成

T1. 输出第二个整数

输入三个整数,把第二个输入的整数输出。

时间限制:1 s
内存限制:64 MB

  • 输入
    只有一行,共三个整数,整数之间由一个空格分隔。整数是 32 32 32 位有符号整数。
  • 输出
    只有一行,一个整数,即输入的第二个整数。
  • 样例输入
    123 456 789
    
  • 样例输出
    456
    

思路分析

此题考查基本输入输出,属于入门题。按照题意进行输入,然后输出第二个变量即可。

/*
 * Name: T1.cpp
 * Problem: 输出第二个整数
 * Author: Teacher Gao.
 * Date&Time: 2024/02/28 22:50
 */

#include <iostream>

using namespace std;

int main()
{
    int a, b, c;
    cin >> a >> b >> c;

    cout << b << endl;

    return 0;
}

T2. 计算表达式的值

给定整数 x x x y y y 的值,计算 3 × x + 2 × y 3 \times x+2 \times y 3×x+2×y 的值。

时间限制:1 s
内存限制:64 MB

  • 输入
    一行包含 2 2 2 个整数 x , y x,y x,y,以空格作为分隔。数据保证最后计算结果还在整数表示范围内。
  • 输出
    按照题目要求输出结果。
  • 样例输入
    2 3
    
  • 样例输出
    12
    

思路分析

此题考查基本输入输出与算术运算,属于入门题。按照题意输入 xy,然后输出 3*x + 2*y 即可。

/*
 * Name: T2.cpp
 * Problem: 计算表达式的值
 * Author: Teacher Gao.
 * Date&Time: 2024/02/29 03:10
 */

#include <iostream>

using namespace std;

int main()
{
    int x, y;
    cin >> x >> y;

    cout << 3*x + 2*y;

    return 0;
}

T3. 大写字母的判断

此题为 2021 年 6 月一级第三题原题,见 2021 年 6 月青少年软编等考 C 语言一级真题解析中的 T3。

T4. 满足条件的数的累加

此题为 2021 年 9 月一级第四题原题,见 2021 年 9 月青少年软编等考 C 语言一级真题解析中的 T4。

T5. 金币

国王将金币作为工资,发放给忠诚的骑士。第一天,骑士收到一枚金币;之后两天(第二天和第三天)里,每天收到两枚金币;之后三天(第四、五、六天)里,每天收到三枚金币;之后四天(第七、八、九、十天)里,每天收到四枚金币 … … 这种工资发放模式会一直这样延续下去:当连续 n n n 天每天收到 n n n 枚金币后,骑士会在之后的连续 n + 1 n+1 n+1 天里,每天收到 n + 1 n+1 n+1 枚金币( n n n 为任意正整数)。

你需要编写一个程序,确定从第一天开始的给定天数内,骑士一共获得了多少金币。

时间限制:1 s
内存限制:128 MB

  • 输入
    一个正整数,表示天数。范围 1 1 1 10000 10000 10000
  • 输出
    骑士获得的金币数。
  • 样例输入
    6
    
  • 样例输出
    14
    

思路分析

此题考查循环嵌套,属于一般应用题。此题为 2015 年 NOIP 普及组复赛原题,更详细的解析见【NOIP 2015 普及组】金币这篇文章。

这里没有什么理论分析,我们直接讲代码。首先定义一个计数器变量 coin,初始值为 1 1 1,用于表示每天需要发放给骑士的金币数量。另设一个累加器变量 total,初始值为 0 0 0,用于表示骑士获得的金币总数。

然后用外层循环来记录已发放金币的总天数,用内层循环来发放金币,当然了,内层循环也需要控制已发放金币的总天数。具体来讲,每发放一次金币,就需要累加一天。在下面的代码中,变量 iday 都是用来记录天数的,i 用来记录 coin 枚金币发放的天数,day 用来记录已发放金币的总天数。每当内层循环结束之后,coin 的值需要加一。该算法的时间复杂度为 O ( n ) O(n) O(n)

/*
 * Name: coin1.cpp
 * Problem: 金币
 * Author: Teacher Gao.
 * Date&Time: 2024/03/07 23:26
 */

#include <iostream>

using namespace std;

int main()
{
    int n;
    cin >> n;
      
    int total = 0, coin = 1;
    for (int day = 1; day <= n; ) {
        for (int i = 1; i <= coin && day <= n; i++) {
            total += coin;
            day++;
        }
        coin++;
    }
     
    cout << total << endl;
    
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

朔北之忘 Clancy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值