2022年09月 C/C++(六级)真题解析#中国电子学会#全国青少年软件编程等级考试

在这里插入图片描述

C/C++编程(1~8级)全部真题・点这里

第1题:stack or queue

栈和队列都是常用的线性结构,它们都提供两个操作:
Push:加入一个元素。
Pop:弹出一个元素。
不同的是,栈是”先进后出”,而队列则是”先进先出”。
给出一个线性结构的进出顺序,判定这个结构是栈还是队列。
时间限制:1000
内存限制:65535
输入
第一行输入一个整数t,代表有t组测试数据 对于每组测试数据,第一行输入一个整数n,代表操作的次数。 随后输入n行,每行包含两个整数 type val。 当type = 1时,表示该次操作为push操作,val表示进入的数字。当type=2时,表示该次操作为pop操作,val代表出来的数字。 3<=n<=2000
输出
每组测试数据输出一行。 输出该组数据对应的线性结构,”Stack” 或者 “Queue”。 题目保证是栈或者队列的一种。
样例输入
2
6
1 1
1 2
1 3
2 3
2 2
2 1
4
1 1
1 2
2 1
2 2
样例输出
Stack
Queue

以下是一个用C语言实现的解答示例:

#include <stdio.h>#define MAX_SIZE 2000typedef struct {int data[MAX_SIZE];int top;
} Stack;typedef struct {int data[MAX_SIZE];int front;int rear;
} Queue;void initStack(Stack *stack) {stack->top = -1;
}void initQueue(Queue *queue) {queue->front = 0;queue->rear = -1;
}void pushStack(Stack *stack, int value) {stack->data[++stack->top] = value;
}int popStack(Stack *stack) {return stack->data[stack->top--];
}void enqueue(Queue *queue, int value) {queue->data[++queue->rear] = value;
}int dequeue(Queue *queue) {return queue->data[queue->front++];
}int main() {int t;scanf("%d", &t);while (t--) {int n;scanf("%d", &n);int type, val;int isStack = 1; // Assume it's a stack initiallyint isQueue = 1; // Assume it's a queue initiallyStack stack;Queue queue;initStack(&stack);initQueue(&queue);while (n--) {scanf("%d %d", &type, &val);if (type == 1) {pushStack(&stack, val);enqueue(&queue, val);} else if (type == 2) {if (isStack) {if (val != popStack(&stack))isStack = 0;}if (isQueue) {if (val != dequeue(&queue))isQueue = 0;}}}if (isStack && !isQueue)printf("Stack\n");else if (!isStack && isQueue)printf("Queue\n");}return 0;
}

这个程序首先定义了栈(Stack)和队列(Queue)的结构体,然后实现了初始化栈和队列的函数。接下来,根据输入的操作类型和值,通过调用相应的函数来模拟栈和队列的操作。在每次出栈或出队列的操作中,都会判断是否满足栈或队列的特性,如果不满足,则将相应的标志位(isStack和isQueue)设置为0。最后,根据标志位的值输出结果。

注意:该程序假设输入的操作序列要么是栈,要么是队列,不能同时满足栈和队列的特性。

第2题:栈的基本操作

栈是一种重要的数据结构,它具有push k和pop操作。push k是将数字k加入到栈中,pop则是从栈中取一个数出来。
栈是后进先出的:把栈也看成横向的一个通道,则push k是将k放到栈的最右边,而pop也是从栈的最右边取出一个数。
假设栈当前从左至右含有1和2两个数,则执行push 5和pop操作示例图如下:
push 5 pop
1
栈 1 2 -------> 1 2 5 ------> 1 2
现在,假设栈是空的。给定一系列push k和pop操作之后,输出栈中存储的数字。若栈已经空了,仍然接收到pop操作,
则输出error。
时间限制:1000
内存限制:65536
输入
第一行为m,表示有m组测试输入,m<100。 每组第一行为n,表示下列有n行push k或pop操作。(n<150) 接下来n行,每行是push k或者pop,其中k是一个整数。 (输入保证同时在栈中的数不会超过100个)
输出
对每组测试数据输出一行。该行内容在正常情况下,是栈中从左到右存储的数字,数字直接以一个空格分隔,如果栈空,则不作输出;但若操作过程中出现栈已空仍然收到pop,则输出error。
样例输入
2
4
push 1
push 3
pop
push 5
1
pop
样例输出
1 5
error

以下是一个用C语言实现的解答示例:

#include <stdio.h>
#include <string.h>#define MAX_SIZE 100typedef struct {int data[MAX_SIZE];int top;
} Stack;void initStack(Stack *stack) {stack->top = -1;
}void push(Stack *stack, int value) {stack->data[++stack->top] = value;
}int pop(Stack *stack) {return stack->data[stack->top--];
}int isEmpty(Stack *stack) {return stack->top == -1;
}int main() {int m;scanf("%d", &m);while (m--) {int n;scanf("%d", &n);Stack stack;initStack(&stack);int i;char operation[5];int value;for (i = 0; i < n; i++) {scanf("%s", operation);if (strcmp(operation, "push") == 0) {scanf("%d", &value);push(&stack, value);} else if (strcmp(operation, "pop") == 0) {if (isEmpty(&stack)) {printf("error\n");break;} else {pop(&stack);}}}if (isEmpty(&stack))continue;while (!isEmpty(&stack)) {printf("%d ", pop(&stack));}printf("\n");}return 0;
}

该程序首先定义了栈(Stack)的结构体,然后实现了初始化栈、入栈(push)、出栈(pop)以及判断栈是否为空的函数。

在主函数中,首先读取测试数据的数量m,然后通过循环处理每组测试数据。对于每组测试数据,首先读取操作的数量n。随后,通过循环逐行读取操作,并根据操作类型执行相应的操作。如果收到pop操作时栈已经为空,则输出"error",并跳出当前循环。在处理完n行操作后,如果栈不为空,则依次出栈并输出栈中的数字。

注意:根据题目要求,如果栈为空且仍然收到pop操作,则输出"error"。

第3题:发型糟糕的一天

农夫John 的N(1 ≤ N ≤ 80,000)只奶牛中,有一些也许正在经历发型糟糕的一天。每只奶牛对自己乱糟糟的发型都有自知之明,农夫John想知道所有奶牛能看到其他奶牛头顶的数量之和。
任意奶牛i身高记为 hi (1 ≤ hi ≤ 1,000,000,000),所有奶牛面向东方(本题示意图的右面)依次站成一条线。因此,奶牛i能够看到在它前面的(奶牛i+1,i+2…)所有身高比它低的奶牛,直到被一头比它高的奶牛挡住
考虑如下的例子:
= =
= - = Cows facing right ->
= = =
= - = = =
= = = = = =
1 2 3 4 5 6 奶牛#1 可以看见奶牛#2, 3, 4的头顶
奶牛#2 无法看到任何奶牛的头顶
奶牛#3可以看见奶牛#4的头顶
奶牛#4无法看到任何奶牛的头顶
奶牛#5可以看见奶牛#6的头顶
奶牛#6无法看到任何奶牛的头顶!
用ci表示奶牛i能够看到头顶的奶牛个数;请计算c1 至cN的和。对于上面这个例子,其和为:3 + 0 + 1 + 0 + 1 + 0 = 5。
时间限制:2000
内存限制:65536
输入
第1行:奶牛数N第2行至N+1行:第i+1行包含一个整数,表示奶牛i的高度
输出
第1行:c1 至cN的累加和
样例输入
6
10
3
7
4
12
2
样例输出
5

这个问题可以通过使用栈来解决。我们可以从左到右遍历奶牛的身高,维护一个递增的栈,栈中存储的是奶牛的身高。

对于每只奶牛,我们需要找到它能看到的头顶奶牛数量。我们可以从栈顶开始,比较当前奶牛的身高和栈顶奶牛的身高。如果当前奶牛的身高大于栈顶奶牛的身高,那么栈顶奶牛就不会被当前奶牛看到,我们可以将其从栈中弹出。在这个过程中,我们可以计算栈顶奶牛能看到的头顶奶牛数量,并将其累加到最终的结果中。

最后,我们将当前奶牛的身高入栈。重复以上步骤直到遍历完所有的奶牛。

以下是一个用C语言实现的解答示例:

#include <stdio.h>#define MAX_SIZE 80000typedef struct {int height;int count;
} Cow;typedef struct {Cow data[MAX_SIZE];int top;
} Stack;void initStack(Stack *stack) {stack->top = -1;
}void push(Stack *stack, Cow value) {stack->data[++stack->top] = value;
}Cow pop(Stack *stack) {return stack->data[stack->top--];
}Cow top(Stack *stack) {return stack->data[stack->top];
}int main() {int N;scanf("%d", &N);Cow cows[MAX_SIZE];int i;for (i = 0; i < N; i++) {scanf("%d", &(cows[i].height));cows[i].count = 0;}Stack stack;initStack(&stack);long long total = 0;for (i = 0; i < N; i++) {while (stack.top >= 0 && cows[i].height >= top(&stack).height) {cows[i].count += top(&stack).count + 1;pop(&stack);}total += cows[i].count;push(&stack, cows[i]);}printf("%lld\n", total);return 0;
}

该程序首先定义了奶牛(Cow)和栈(Stack)的结构体。奶牛结构体包含奶牛的身高和能看到的头顶奶牛数量,栈结构体用于存储奶牛。

在主函数中,首先读取奶牛的数量N,并初始化奶牛数组。然后,使用一个循环从输入中读取每只奶牛的身高,并将其存储在奶牛数组中。同时,初始化一个栈。

接下来,使用一个循环遍历奶牛数组。对于每只奶牛,我们从栈顶开始,比较当前奶牛的身高和栈顶奶牛的身高。如果当前奶牛的身高大于栈顶奶牛的身高,我们将栈顶奶牛从栈中弹出,并计算栈顶奶牛能看到的头顶奶牛数量。然后,将这个数量累加到当前奶牛的count属性中。重复以上步骤直到当前奶牛的身高小于等于栈顶奶牛的身高。最后,将当前奶牛入栈。

在遍历完所有奶牛后,我们将每只奶牛的count属性累加到总和total中,并输出结果。

注意:由于结果可能非常大,所以使用了long long类型来保存总和total。

第4题:合影效果

小云和朋友们去爬香山,为美丽的景色所陶醉,想合影留念。如果他们站成一排,男生全部在左(从拍照者的角度),并按照从矮到高的顺序从左到右排,女生全部在右,并按照从高到矮的顺序从左到右排,请问他们合影的效果是什么样的(所有人的身高都不同)?
时间限制:1000
内存限制:65536
输入
第一行是人数n(2 <= n <= 40,且至少有1个男生和1个女生)。 后面紧跟n行,每行输入一个人的性别(男male或女female)和身高(浮点数,单位米),两个数据之间以空格分隔。
输出
n个浮点数,模拟站好队后,拍照者眼中从左到右每个人的身高。每个浮点数需保留到小数点后2位,相邻两个数之间用单个空格隔开。
样例输入
6
male 1.72
male 1.78
female 1.61
male 1.65
female 1.70
female 1.56
样例输出
1.65 1.72 1.78 1.70 1.61 1.56

这个问题可以通过对输入进行处理,并按照规定的顺序排列人的身高来解决。

首先,我们可以创建一个结构体来表示每个人,包括其性别和身高信息。

然后,我们可以根据输入的性别和身高信息,将男生和女生分别存储在两个不同的数组中。

接下来,我们可以对男生数组按照身高从矮到高进行排序,并对女生数组按照身高从高到矮进行排序。

最后,我们可以创建一个结果数组,按照排好序的顺序将男生和女生的身高依次填入。

以下是一个用C语言实现的解答示例:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>#define MAX_SIZE 40typedef struct {char gender[10];float height;
} Person;int compare(const void *a, const void *b) {Person *personA = (Person *)a;Person *personB = (Person *)b;if (strcmp(personA->gender, "male") == 0 && strcmp(personB->gender, "male") == 0) {return personA->height - personB->height;} else if (strcmp(personA->gender, "female") == 0 && strcmp(personB->gender, "female") == 0) {return personB->height - personA->height;} else if (strcmp(personA->gender, "male") == 0 && strcmp(personB->gender, "female") == 0) {return -1;} else {return 1;}
}int main() {int n;scanf("%d", &n);Person people[MAX_SIZE];Person males[MAX_SIZE];Person females[MAX_SIZE];int maleCount = 0;int femaleCount = 0;int i;for (i = 0; i < n; i++) {scanf("%s %f", people[i].gender, &(people[i].height));if (strcmp(people[i].gender, "male") == 0) {males[maleCount++] = people[i];} else {females[femaleCount++] = people[i];}}qsort(males, maleCount, sizeof(Person), compare);qsort(females, femaleCount, sizeof(Person), compare);float result[MAX_SIZE];int resultCount = 0;int maleIndex = 0;int femaleIndex = 0;for (i = 0; i < n; i++) {if (strcmp(males[maleIndex].gender, "male") == 0) {result[resultCount++] = males[maleIndex++].height;} else {result[resultCount++] = females[femaleIndex++].height;}}for (i = 0; i < n; i++) {printf("%.2f ", result[i]);}printf("\n");return 0;
}

该程序首先定义了一个表示人的结构体(Person),其中包括性别和身高属性。

在主函数中,首先读取人数n,并创建用于存储所有人的数组(people)以及男生(males)和女生(females)的数组。

然后,使用一个循环从输入中读取每个人的性别和身高,并将其存储在对应的数组中。

接下来,使用qsort函数对男生和女生的数组进行排序,排序规则由compare函数定义。compare函数首先比较性别,如果都是男生或女生,则按照身高从矮到高或从高到矮排序;如果一个是男生一个是女生,则男生在前,女生在后。

最后,创建一个结果数组(result)和一个计数变量(resultCount),并使用两个索引变量(maleIndex和femaleIndex)分别指向男生数组和女生数组的起始位置。使用一个循环将男生和女生的身高按照排好序的顺序依次填入结果数组,并增加计数变量的值。

最后,使用一个循环输出结果数组中的身高,保留两位小数,并用空格隔开。

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

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

相关文章

leetcode236. 二叉树的最近公共祖先(java)

二叉树的最近公共祖先 题目描述递归法代码演示 上期经典 题目描述 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个节点 p、q&#xff0c;最近公共祖先表示为一个节点 x&#xff0c;满足 x 是 p、q …

Ae 效果:CC Light Rays

生成/CC Light Rays Generate/CC Light Rays CC Light Rays&#xff08;CC 光线&#xff09;可以创建从光源发出并能穿过图层内容的光线效果。常用于制作光线透过门窗或云层的场景&#xff0c;或者用于创建神奇或梦幻的氛围感。 本效果会被限制在源图层的大小范围之内。 ◆ ◆…

每日一题 98验证二叉搜索树(中序遍历)

题目 给你一个二叉树的根节点 root &#xff0c;判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下&#xff1a; 节点的左子树只包含 小于 当前节点的数。节点的右子树只包含 大于 当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。 示例 1&#xff1a…

【负载均衡】常见的负载均衡策略有哪些?

文章目录 前言负载均衡分类常见负载均衡策略小结 前言 负载均衡策略是实现负载均衡器的关键&#xff0c;而负载均衡器又是分布式系统中不可或缺的重要组件。使用它有助于提高系统的整体性能、可用性、可靠性和安全性&#xff0c;同时支持系统的扩展和故障容忍性。对于处理大量…

基于 Docker 的 MySQL 主从复制搭建(Mac M1版本)

系统&#xff1a;Macbook M1 镜像版本&#xff1a;mysql:5.7 如果是要查 slave连接不上 master的问题&#xff0c;可以直接跳到文章末尾踩坑处 准备工作 拉取镜像 docker pull mysql:5.7本地数据卷挂载 因为mysql不挂载的话&#xff0c;重启丢失数据&#xff0c;所以在本地创…

微服务--Gatway:网关

routes: - id:order_route(路由唯一 标识&#xff0c;路由到order) uri&#xff1a;http://localhost:8020 #需要转发的地址 #断言规则&#xff08;用于路由规则的匹配&#xff09; predicates: -path/order-serv/** -pathlb://order-service # lb: 使用nacos中的本地…

分享码云上8个宝藏又有价值的开源图片编辑器

如果你需要高效地处理图片&#xff0c;那么这8款实用工具是可以尝试的&#xff01; 它们能够进行一键抠图、放大、拼接、转矢量图、图标自动生成以及等操作&#xff0c;让你的工作效率飞升&#xff01; 在Gitee这个最有价值的开源项目计划是Gitee综合评定出的优秀开源项目的展示…

springboot web开发springmvc自动配置原理

前言 我们也知道springboot启用springmvc基本不用做什么配置可以很方便就使用了但是不了解原理,开发过程中遇到点问题估计就比较头疼,不管了解的深不深入,先巴拉一番再说… 下面我们先看看官网…我的版本是2.3.2版本,发现官网改动也比较大…不同版本自己巴拉下吧,结构虽然变化…

C++文件操作

一、fstream简介 C 提供了一组用于文件操作的标准库fstream&#xff0c;可以进行文件的读取、写入和其他相关操作。常用的文件操作包括文件的打开、关闭、读取、写入和定位等。下面是一些常见的文件操作函数&#xff1a; 文件的打开和关闭&#xff1a; std::ofstream&#x…

leetcode 941. 有效的山脉数组

2023.9.2 可以用双指针法来做&#xff0c;left指向数组起点&#xff0c;right指向数组终点&#xff0c;left满足条件则左移&#xff0c;right满足条件则右移&#xff0c;最终两指针重合则返回true。 期间任一条件不满足则返回false。 代码如下&#xff1a; class Solution { p…

大数据时代下的数据安全防护

随着大数据时代的来临&#xff0c;数据安全防护成为了一个重要的问题。在大数据时代&#xff0c;数据的规模和价值都得到了极大的提升&#xff0c;因此数据安全的重要性也变得越来越突出。本文将从数据加密、访问控制、网络安全和人员管理四个方面来介绍大数据时代下的数据安全…

什么是盒子模型

什么是盒子模型 盒子模型&#xff0c;也可以称为框模型。 所有 HTML 元素可以看作盒子。在 CSS 中&#xff0c;“box model” 这一术语是用来设计和布局时使用。 CSS 盒模型本质上是一个盒子&#xff0c;封装周围的 HTML 元素&#xff0c;它包括&#xff1a;边距&#xff0c…

8. 损失函数与反向传播

8.1 损失函数 ① Loss损失函数一方面计算实际输出和目标之间的差距。 ② Loss损失函数另一方面为我们更新输出提供一定的依据。 8.2 L1loss损失函数 ① L1loss数学公式如下图所示&#xff0c;例子如下下图所示。 import torch from torch.nn import L1Loss inputs torch.tens…

Django静态文件媒体文件文件上传

文章目录 一、静态文件和媒体文件1.在django中使用静态文件实践2.在django中使用媒体文件 二、文件上传单文件上传实践多文件上传 一、静态文件和媒体文件 媒体文件: 用户上传的文件&#xff0c;叫做media 静态文件:存放在服务器的css,js,image,font等 叫做static1.在django中…

【Locomotor运动模块】瞬移

文章目录 一、原理二、两种类型1、Instant(立刻)2、Dash&#xff08;猛冲&#xff09; 三、瞬移区域、瞬移点1、瞬移区域2、瞬移点 一、原理 抛物线指针选择好目标位置&#xff0c;然后告诉瞬移预设体&#xff1a;你想法把游戏区域弄到目标位置来 解释&#xff1a;抛物线指针选…

JS中的new操作符

文章目录 JS中的new操作符一、什么是new&#xff1f;二、new经历了什么过程&#xff1f;三、new的过程分析四、总结 JS中的new操作符 参考&#xff1a;https://www.cnblogs.com/buildnewhomeland/p/12797537.html 一、什么是new&#xff1f; 在JS中&#xff0c;new的作用是通过…

React笔记(八)Redux

一、安装和配置 React 官方并没有提供对应的状态机插件&#xff0c;因此&#xff0c;我们需要下载第三方的状态机插件 —— Redux。 1、下载Redux 在终端中定位到项目根目录&#xff0c;然后执行以下命令下载 Redux npm i redux 2、创建配置文件 在 React 中&#xff0c;…

FreeRTOS的信号量和互斥量之间的区别和联系

文章目录 信号量信号量简介信号量特征 互斥量互斥量的上锁机制互斥量的优先级继承机制 二值信号量和互斥量的作用二值信号量的作用互斥量的作用 二值信号量和互斥锁关系相同点不同点 如何根据场景选择回答信号量和互斥锁之间的区别&#xff1a; 信号量 信号量简介 队列(queue)…

大集合按照指定长度进行分割成多个小集合,用于批量多次处理数据

&#x1f4da;目录 拆分案例拆分的核心代码 通常我们对集合的更新或者保存都需要用集合来承载通过插入的效率&#xff0c;但是这个会遇到一个问题就是你不知道那天那个集合的数量可能就超了&#xff0c;虽然我们连接数据库进行批量提交会在配置上配置allowMultiQueriestrue,但是…

类和对象(下)

&#x1f493;博主个人主页:不是笨小孩&#x1f440; ⏩专栏分类:数据结构与算法&#x1f440; C&#x1f440; 刷题专栏&#x1f440; C语言&#x1f440; &#x1f69a;代码仓库:笨小孩的代码库&#x1f440; ⏩社区&#xff1a;不是笨小孩&#x1f440; &#x1f339;欢迎大…