中国电子学会(CEIT)考评中心历届真题(含解析答案)
C语言软件编程等级考试一级 2020年12月
编程题五道 总分:100分
一、数组指定部分逆序重放(20分)
将一个数组中的前k项按逆序重新存放。例如,将数组8,6,5,4,1前3项逆序重放得到5,6,8,4,1。
时间限制: 1000ms
内存限制: 65536kb
输入
输入为两行:第一行两个整数,以空格分隔,分别为数组元素的个数n (1 <n <100)以及指定的k(1 <= k <= n)。第二行是n个整数,每两个整数之间用空格分隔。
输出
输出为一行:输出按题目要求逆序后数组的整数,每两个整数之间用空格分隔。
样例输入
5 3
8 6 5 4 1
样例输出
5 6 8 4 1
#include <stdio.h>
int main() {
int n,k,a[100];
scanf("%d %d",&n,&k);
for(int i=0; i<n; i++){
if(i<k)
scanf("%d",&a[k-i-1]);//输入的时候前k项按照逆序存放
else
scanf("%d",&a[i]);//其它项正常存放
}
for(int i=0; i<n; i++)
printf("%d ",a[i]);
return 0;
}
二、简单密码(20分)
Julius Caesar曾经使用过一种很简单的密码。对于明文中的每个字符,将它用它字母表中后5位对应的字符来代替,这样就得到了密文。比如字符A用F来代替。如下是密文和明文中字符的对应关系。密文A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 明文V W X Y Z A B C D E F G H I J K L M N O P Q R S T U 你的任务是对给定的密文进行解密得到明文。你需要注意的是,密文中出现的字母都是大写字母。密文中也包括非字母的字符,对这些字符不用进行解码。
时间限制: 1000ms
内存限制: 65536kb
输入
一行,给出密文,密文不为空,而且其中的字符数不超过200。
输出
输出一行,即密文对应的明文。
样例输入
NS BFW,JAJSYX TK NRUTWYFSHJ FWJ YMJ WJXZQY TK YWNANFQ HFZXJX
样例输出
IN WAR, EVENTS OF IMPORTANCE ARE THE RESULT OF TRIVIAL CAUSES
#include <stdio.h>
#include <string.h>
int main() {
char s[201];
char m[201]= {
0};
gets(s);
for(int i=0; i<strlen(s); i++){
if(s[i]>='A'&& s[i]<='Z'){
//解密,向前移动5位
//等价于是向后移动21位
m[i]=(s[i]-'A'+21)%26+'A';