7-1 考试周 (5分)
考试周快到了,浙江大学的电子屏又调皮了…… 本题请你帮小编写一个自动倒计时的程序,对给定的日期(例如“腊八”就对应 8)和倒计时天数(例如电子屏上的“四天之后”就对应 4),自动调整公式里的分母(例如 8/2=4 里面的那个 2)。
输入格式:
输入在一行中给出两个正整数:A 是给定的日期,不超过 30;B 是倒计时天数,不超过 10。
输出格式:
在一行中输出公式 A/X=B,其中 X 是满足等式的数字,输出时保留小数点后 1 位即可。
输入样例:
8 3
输出样例:
8/2.7=3
#include <bits/stdc++.h>
using namespace std;
int main()
{
double a,b;
cin>>a>>b;
printf("%0.0f",a);
printf("/");
printf("%0.1f",a/b);
printf("=");
printf("%0.0f",b);
return 0;
}
7-2 真的恭喜你 (10分)
当别人告诉你自己考了 x 分的时候,你要回答说:“恭喜你考了 x 分!”比如小明告诉你他考了90分,你就用汉语拼音打出来 gong xi ni kao le 90 fen!。
但是如果小明没考好,比如只考了 20 分,你也“恭喜”人家就不对了。这时候你应该安慰他说:“考了 20 分别泄气!”用汉语拼音写出来就是 kao le 20 fen bie xie qi!。
输入格式:
输入在一行里给出一位小朋友的分数。这个分数是一个 0 到 100 之间的整数。
输出格式:
在一行中输出你对这位小朋友说的话。如果人家考到不低于 90 分,就说 gong xi ni kao le X fen!;如果不到 90 分,就说 kao le X fen bie xie qi!。其中 X 是小朋友输入的分数。
输入样例 1:
95
输出样例 1:
gong xi ni kao le 95 fen!
输入样例 2:
89
输出样例 2:
kao le 89 fen bie xie qi!
#include <bits/stdc++.h>
using namespace std;
int main(){
int a;
cin>>a;
if(a>=90&&a<=100){
cout<<"gong xi ni kao le "<<a<<" fen!"<<endl;
}
else{
cout<<"kao le "<<a<<" fen bie xie qi!"<<endl;
}
return 0;
}
7-3 平均成绩 (10分)
给定一所学校学生的体育成绩,请你统计全班的平均成绩和男生、女生的平均成绩。
输入格式:
输入首先在第一行中给出一个正整数 N(≤10000),即全校学生人数。最后 N 行,每行按照格式 性别 成绩 给出一位学生的信息。其中 性别 为 1 表示男生,0 表示女生;成绩 是一个 0 到 100 之间的整数。
输出格式:
在一行中依次输出全班的平均成绩、男生的平均成绩、女生的平均成绩。输出小数点后1位,数字间有一个空格分隔。
注意:如果全是男生或全是女生,则缺少的性别就没有办法计算平均分,相应的位置应该输出一个 X 表示没有。
输入样例 1:
5
1 97
0 91
0 98
1 95
1 90
输出样例 1:
94.2 94.0 94.5
输入样例 2:
5
0 97
0 91
0 98
0 95
0 90
输出样例 2:
94.2 X 94.2
#include <bits/stdc++.h>
using namespace std;
int main(){
int n,s1=0,s2=0;
cin>>n;
double c=0,c1=0,c2=0;
for(int i=0;i<n;i++){
int s,g;
cin>>s>>g;
if(s==1){
c1+=g;
s1++;
}
if(s==0){
c2+=g;
s2++;
}
c=c1+c2;
}
printf("%0.1f",c/n);
if(s1==0){
printf(" X");
}else{
printf(" %0.1f",c1/s1);
}
if(s2==0){
printf(" X");
}else{
printf(" %0.1f",c2/s2);
}
}
7-4 古风A+B (15分)
给定两个绝对值不超过 109 的整数 A 和 B,计算它们的和 A+B 是非常简单的事,但要将和这个数字按照中国古风从上到下竖着输出,就不是那么简单了吧?
输入格式:
输入在一行中给出 2 个绝对值不超过 109 的整数 A 和 B,其间以空格分隔。
输出格式:
将 A+B 数值的每一位从上到下竖着输出。如果是负数,那么负号占第 1 行,其它数字不用输出符号。
输入样例:
-6666 233
输出样例:
-
6
4
3
3
#include <bits/stdc++.h>
#include <string>
using namespace std;
int main(){
int a,b,c;
cin>>a>>b;
c=a+b;
string s=to_string(c);
int n=s.length();
cout<<s[0];
for(int i=1;i<n;i++){
cout<<endl<<s[i];
}
}
7-5 猜近似数字 (15分)
甲想好了一个 n 位数字让乙来猜,只要猜的数字位数正确,至多有 1 位与谜底不同,且不同的数字相差不超过 1,就算猜对了。例如谜底是 67,若乙猜 66、68、77、57,就都算对了;猜 167 就不能算对。
输入格式:
输入首先在第一行给出一个不超过 1000 位数的、最高位不是 0 的正整数,是甲给出的谜底。随后若干行,每行给出一个乙猜的数字,都是最高位不是 0 的正整数。直到出现 -1 表示输入结束,这个数字不要做任何处理。题目保证乙至少猜了一次。
输出格式:
对每一个乙猜的数字,如果猜对了就输出 Yes,否则输出 No。
输入样例:
12345678909876
2345678909876
12345678900876
12345678809876
12345678909888
1234567890987
-1
输出样例:
No
No
Yes
No
No
#include <bits/stdc++.h>
#include <string>
using namespace std;
int main(){
string s;
cin>>s;
int sum=s.length();
while(1){
string a;
cin>>a;
if(a=="-1") break;
int asum=a.length();
if(sum!=asum){
cout<<"No"<<endl;
continue;
}
if(sum==asum){
int count1=0;
int count2=0;
for(int i=0;i<sum;i++){
if(s[i]!=a[i]){
count1++;
if(count1>1){
break;
}
if(abs(s[i]-a[i])==1){
count2++;
}
}
}
if((count1==1&&count2==1)||count1==0){
cout<<"Yes"<<endl;
}else{
cout<<"No"<<endl;
}
}
}
}
太菜了一个小时就做对这几个题,剩下两个20分的题部分正确,俩题得了10分,,,,,,,25分的题没时间了