第1题:字符长方形
给定一个字符,用它构造一个长为4个字符,宽为3个字符的长方形,可以参考样例输出。
时间限制:1000
内存限制:65536
输入
输入只有一行, 包含一个字符。
输出
该字符构成的长方形,长4个字符,宽3个字符。
样例输入
*
样例输出
****
****
****
以下是使用C语言编写的解决方案:
#include <stdio.h>int main() {char ch;// 读取输入字符scanf("%c", &ch);// 输出长方形for (int i = 0; i < 3; i++) {for (int j = 0; j < 4; j++) {printf("%c", ch);}printf("\n");}return 0;
}
你可以将上述代码保存为一个名为 “rectangle.c” 的文件,并使用C编译器进行编译和运行。输入一个字符后,程序将输出相应的长方形。
请注意,这个解决方案假设输入的字符是有效的,并且只读取一个字符。如果输入包含多个字符,或者不是有效的字符,可能会导致输出错误。
第2题:长方形面积
给出一个长方形的长和宽,求该长方形的面积。假设长为a,宽为b,则面积S=a×b。
时间限制:1000
内存限制:65536
输入
一行,2个正整数,以空格分隔,分别表示长方形的长和宽。长和宽都不大于1000。
输出
一个整数,即长方形的面积。
样例输入
4 3
样例输出
12
以下是解决该问题的C语言代码:
#include <stdio.h>int main() {int length, width, area;// 读取输入的长和宽scanf("%d %d", &length, &width);// 计算面积area = length * width;// 输出面积printf("%d\n", area);return 0;
}
你可以将上述代码保存为一个名为 “rectangle_area.c” 的文件,并使用C编译器进行编译和运行。在输入长和宽后,程序将计算并输出长方形的面积。
请注意,这个解决方案假设输入的长和宽都是有效的正整数,并且在题目要求的范围内。如果输入包含非法字符、负数或超出限制范围的数值,可能会导致输出错误。
第3题:成绩等级转换
小明想将自己的百分制成绩转换为等级制,请你帮他完成这样的转换。转换规则为:
A,90-100
B,77-89
C,67-76
D,60-66
E,0-59
时间限制:1000
内存限制:65536
输入
一个0 - 100 的整数
输出
输出转换后的等级,一个A-E的大写字母。
样例输入
样例1:
85
样例2:
62
样例输出
样例1:
B
样例2:
D
以下是解决该问题的C语言代码:
#include <stdio.h>char convertToGrade(int score) {if (score >= 90 && score <= 100) {return 'A';} else if (score >= 77 && score <= 89) {return 'B';} else if (score >= 67 && score <= 76) {return 'C';} else if (score >= 60 && score <= 66) {return 'D';} else {return 'E';}
}int main() {int score;// 读取输入的成绩scanf("%d", &score);// 转换成绩为等级char grade = convertToGrade(score);// 输出等级printf("%c\n", grade);return 0;
}
你可以将上述代码保存为一个名为 “grade_conversion.c” 的文件,并使用C编译器进行编译和运行。在输入成绩后,程序将根据转换规则将其转换为相应的等级,并输出等级。
请注意,这个解决方案假设输入的成绩是有效的整数,并且在题目要求的范围内。如果输入包含非法字符、小数或超出限制范围的数值,可能会导致输出错误。
第4题:寻找特殊年号
年号中的每个数之和为20的年号是特殊年号。例如:2099、1991、1892是特殊的年号,而2021则不是。给定一个年号,找出严格大于给定年号的最小特殊年号。
时间限制:1000
内存限制:65535
输入
年号:整数y(1000≤y≤9000)。
输出
特殊年号:严格意义上大于y的最小年号,并且它的每个数之和为20。
样例输入
样例输入1
1892
样例输入2
2021
样例输出
样例输出1
1919
样例输出2
2099
提示
因为2+0+9+9=20,所以2099是特殊年号。 因为2+0+2+1=5,所以2021不是特殊年号。 特殊年号可能大于9000。
以下是解决该问题的C语言代码:
#include <stdio.h>int sumOfDigits(int year) {int sum = 0;while (year != 0) {sum += year % 10;year /= 10;}return sum;
}int findSpecialYear(int year) {int specialYear = year + 1;while (sumOfDigits(specialYear) != 20) {specialYear++;}return specialYear;
}int main() {int year;// 读取输入的年号scanf("%d", &year);// 寻找特殊年号int specialYear = findSpecialYear(year);// 输出特殊年号printf("%d\n", specialYear);return 0;
}
你可以将上述代码保存为一个名为 “special_year.c” 的文件,并使用C编译器进行编译和运行。在输入年号后,程序将寻找严格大于给定年号的最小特殊年号,并输出该特殊年号。
请注意,这个解决方案假设输入的年号是有效的整数,并且在题目要求的范围内。如果输入包含非法字符、小数或超出限制范围的数值,可能会导致输出错误。此外,特殊年号可能大于9000,因此解决方案没有对特殊年号的上限进行限制。
第5题:机智的小明
小明的妈妈非常关心小明的成绩,每次考试后都会问小明是否进步了。机智的小明会努力找出之前比这次成绩低的试卷进行比较,如果找到了,他会回答妈妈自己进步了(Y),如果没找到,他只能回答妈妈没进步(N)。已知小明的n次成绩,请问每次妈妈询问小明,小明的回答是怎么样的。
时间限制:1000
内存限制:65536
输入
输入为2行,第1行是一个整数n(n < 100),即考试成绩的数量,第二行是n个整数,即每次考试成绩。输入保证n不大于100,考试成绩在0到100之间。
输出
n行,每行是小明的回答(Y或N)
样例输入
5
90 80 95 96 50
样例输出
N
N
Y
Y
N
提示
对于每一次成绩,只要之前的成绩有任意一次成绩比当前成绩低,就输出Y,否则输出N
以下是解决该问题的C语言代码:
#include <stdio.h>int main() {int n;scanf("%d", &n);int grades[n];for (int i = 0; i < n; i++) {scanf("%d", &grades[i]);}for (int i = 0; i < n; i++) {int currentGrade = grades[i];int foundLowerGrade = 0;for (int j = 0; j < i; j++) {if (grades[j] < currentGrade) {foundLowerGrade = 1;break;}}if (foundLowerGrade) {printf("Y\n");} else {printf("N\n");}}return 0;
}
你可以将上述代码保存为一个名为 “clever_ming.c” 的文件,并使用C编译器进行编译和运行。在输入考试成绩后,程序将根据小明的回答规则输出每次妈妈询问时小明的回答。
请注意,这个解决方案假设输入的考试成绩是有效的整数,并且在题目要求的范围内。如果输入包含非法字符、小数或超出限制范围的数值,可能会导致输出错误。