当前位置:   article > 正文

中国电子学会2022年12月真题C语言软件编程等级考试一级(含解析答案)_c语言考级2022年12月一级试题

c语言考级2022年12月一级试题

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

C语言软件编程等级考试一级 2022年12月

编程题五道							总分:100分
  • 1

一、加一(20分)
输入一个整数x,输出这个整数加1后的值,即x+1的值。
时间限制: 1000
内存限制: 65536
输入
一个整数x (0< x ≤ 1000) 。
输出
按题目要求输出一个整数。
样例输入

9
  • 1

样例输出

10
  • 1
#include <iostream>
using namespace std;
int main(){
	int x;
	//输入一个数
	cin >> x;
	//输出x+1
	cout << x + 1;
	return 0;
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
#include <stdio.h>
int main(){
	int x;
	//输入一个数
	scanf("%d",&x);
	//输出x+1
	printf("%d",x+1);
	return 0;
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

二、(a/b)*c的值(20分)
给定整数a、b、c,计算(a / b)*c的值,这里的除法为实数除法。时间限制:1000
内存限制:65536
输入
—行,三个整数a、b、c,整数间以空格分隔。(1 ≤ a,b,c ≤ 1000)
输出
将计算结果保留6位小数输出。
样例输入

1 3 3
  • 1

样例输出

1.000000
  • 1
#include <stdio.h>
int main(){
	int a,b,c;
	double s;
	//输入a,b,c
	scanf("%d %d %d",&a,&b,&c);
	//计算(a/b)*c,这里需要将a或b转为小数,结果才能是小数
	s=((double)a/b)*c;
	printf("%.6lf" ,s);
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
#include <stdio.h>
int main(){
	int a,b,c;
	double s;
	//输入a,b,c
	scanf("%d %d %d",&a,&b,&c);
	//计算(a/b)*c,这里需要将a或b转为小数,结果才能是小数
	s=((double)a/b)*c;
	printf("%.6lf" ,s);
	return 0;
}
	

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

三、判断是否存在重复的数(20分)
给定3个数,判断是否存在2个数相等,如果存在输出"YES",否者输出"NO"。
时间限制: 5000
内存限制: 65536
输入
1行,包含3个整数,以空格分隔。
输出
按照题目要求输出结果
样例输入

2 7 2
  • 1

样例输出

YES
  • 1
#include <iostream>
using namespace std;
int main() {
	int a, b, c;
	//输入三个数
	cin >> a >> b >> c;
	//判断是否有两个数相等
	if (a == b || b == c || a== c)
		cout <<"YES";
	else
		cout <<"NO";
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
#include <stdio.h>
int main() {
	int a,b,c;
	//输入三个数
	scanf("%d %d %d",&a,&b,&c);
	//判断是否有两个数相等
	if(a==b || b==c || a==c)
		printf("YES");
	else
		printf("NO");
	return 0;
}


  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

四、整数的立方和(20分)
给定一个正整数k (1<k<10),求1到k的立方和m,即m=1+2*2*2+...k*k*k
时间限制: 1000
内存限制: 65536
输入
输入只有一行,该行包含一个正整数k。
输出
输出只有一行,该行包含1到k的立方和。
样例输入

5
  • 1

样例输出

225
  • 1
#include <iostream >
using namespace std;
int main(){
	int i, k;
	int sum = 1;// 1的立方为1,初值为1
	//输入k
	cin >> k;
	//计算2到k的立方和
	for (i = 2; i <= k; i++){
		sum += i * i * i;
	}
	cout << sum;
	return 0;
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
#include <stdio.h>
int main(){
	int i,k;
	int sum=1;//1的立方为1,初值为1
	//输入k
	scanf("%d",&k);//计算2到k的立方和
	for(i=2; i<=k; i++){
		sum+=i*i*i;
	}
	printf("%d",sum);
	return 0;
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

五、自整除数(20分)
对一个整数n,如果其各个位数的数字相加得到的数m能整除n,则称n为自整除数。例如21,21%(2+1)==0,所以21是自整除数。
现求出从10到n(n < 100)之间的所有自整除数。
时间限制: 1000
内存限制: 65536
输入
有一行,整数n。(10 <= n < 100)
输出
有多行。按从小到大的顺序输出所有大于等于10,小于等于n的自整除数,每行一个自整除数。
样例输入

47
  • 1

样例输出

10
12
18
20
21
24
27
30
36
40
42
45
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
#include <stdio.h>
int main(){
	int i,n;
	int a,b;
	//输入n
	scanf(" %d",&n);
	for(i=10; i<=n; i++){
	//取十位和个位数
	a=i/10;
	b=i%10;
	//判断是否自然数
	if(i%(a+b)==0)
		printf("%d\r\n" ,i);
	}
	return 0;
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号