中国电子学会(CEIT)2020年09月真题C语言软件编程等级考试二级(含解析答案)

本文提供了中国电子学会(CEIT)2020年09月C语言软件编程等级考试二级的真题,包括单词倒排、细菌繁殖与扩散、大整数加法、合影效果和循环数等题目,每道题均附带详细的时间限制和内存限制,以及输入输出样例。

中国电子学会(CEIT)考评中心历届真题(含解析答案)

C语言软件编程等级考试二级 2020年09月

编程题五道							总分:100分

一、单词倒排(20分)
编写程序,读入一行英文(只包含字母和空格,单词间以单个空格分隔),将所有单词的顺序倒排并输出,依然以单个空格分隔。
时间限制: 1000ms
内存限制: 65536kb
输入
输入为一个字符串(字符串长度至多为100)。
输出
输出为按要求排序后的字符串。
样例输入

I am a student

样例输出

student a am I
#include <stdio.h>
#include <string.h>
int main() {
   
   
	int i=0,j=0;
	char s[101]= {
   
   0};
	char *p;
	char word[101];
	char list[100][101];
	gets(s);
	//分离每个单词加到list
	p=s;
	while(true) {
   
   
		if(*p=='\0'){
   
   //字符串结束
			strcpy(list[j++],word);
			break;
		} 
		else if(*p==' '){
   
   //遇到空格
			strcpy(list[j++],word);
			memset(word,0,sizeof(word));
			i=0;
		}
		else{
   
   
			word[i++]=*p;
		}
			p++;
	}
	//反向输出单词顺序
	for(i=j-1; i>=0; i--){
   
   
		printf("%s ",list[i]);
	}
	return 0;
}


二、细菌的繁殖与扩散(20分)
在边长为9的正方形培养皿中,正中心位置有m个细菌。假设细菌的寿命仅一天,但每天可繁殖10个后代,而且这10个后代,有两个分布在原来的单元格中,其余的均匀分布在其四周相邻的八个单元格中。求经过n天后,细菌在培养皿中的分布情况。
时间限制: 1000ms
内存限制: 65536kb
输入
输入为两个整数,第一个整数m表示中心位置细菌的个数(2≤m ≤ 30),第二个整数n表示经过的天数(1 ≤n ≤ 4)
输出格式
输出九行九列整数矩阵,每行的整数之间用空格分隔。整个矩阵代表n天后细菌在培养皿上的分布情况。
输入样例

2 1

输出样例

0 0 0 0 0 0 0 0 0 
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 2 2 2 0 0 0
0 0 0 2 4 2 0 0 0
0 0 0 2 2 2 0 0 0 
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
#include <stdio.h>
#include <string.h>
int main() {
   
   
	int d[9][9];
	int b[9][9];
	int m,n;
	scanf("%d %d",&m,&n);
	if(n<0 || n>4)
		return 0;
	//初始化
	memset(d,0,sizeof(d
### 关于电子学会C语言等级考试真题 #### 一级真题分析 以下是基于中国电子学会CEIT)202403月发布的C语言软件编程等级考试一级的一道典型题目及其解答[^1]: ```c #include <stdio.h> int main() { int a, b, c, d; scanf("%d %d %d %d", &a, &b, &c, &d); printf("%d %d %d %d\n", d, c, b, a); return 0; } ``` 此程序的功能是从标准输入读取四个整数并按逆序输出。这是一级考试中的基础操作,主要考察考生对变量定义、基本输入/输出函数以及简单逻辑的理解。 --- #### 四级真题分析 对于更高级别的四级考试,试题难度显著提升,涉及算法设计与复杂数据结构的应用。以下是一个典型的四级考题案例解析[^2]: **问题描述**: 给定一组数组,通过删除某些特定位置的元素后,统计剩余数组中有多少个元素保持在其原始索引位置上。 **解决方案**: 假设初始数组为 `arr`,长度为 `n`,目标是计算经过指定删除操作后的结果。可以通过模拟删除过程来实现这一功能。 ```c #include <stdio.h> #define MAX_SIZE 100 void remove_elements(int arr[], int n, int indices_to_remove[], int m) { int new_arr[MAX_SIZE], index = 0; for (int i = 0; i < n; ++i) { bool should_keep = true; for (int j = 0; j < m; ++j) { if ((indices_to_remove[j] - 1) == i) { // Adjusting to zero-based indexing should_keep = false; break; } } if (should_keep) { new_arr[index++] = arr[i]; } } // Count elements that are at their original positions after removal. int count_in_place = 0; for (int i = 0; i < index; ++i) { if (new_arr[i] == i + 1) { // Check if element is in its position count_in_place++; } } printf("Number of elements in place: %d\n", count_in_place); } int main() { int arr[] = {1, 2, 3, 4, 5}; int size = sizeof(arr) / sizeof(arr[0]); int indices_to_remove[] = {1, 4}; // Remove the first and fourth elements int num_indices = sizeof(indices_to_remove) / sizeof(indices_to_remove[0]); remove_elements(arr, size, indices_to_remove, num_indices); return 0; } ``` 该代码实现了从数组中移除指定索引处的元素,并统计剩余数组中哪些元素仍然位于其原本的位置上。这是四级考试中常见的算法类问题之一。 --- #### 总结 以上分别展示了电子学会C语言等级考试一至四级的部分真题特点。一级侧重基础知识掌握,而四级则更加注重综合能力及实际应用技能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值