题目按分数值递增
7-2 I Love GPLT(5 分)
这道超级简单的题目没有任何输入。
你只需要把这句很重要的话 —— I Love GPLT
——竖着输出就可以了。
所谓“竖着输出”,是指每个字符占一行(包括空格),即每行只能有1个字符和回车。
7-5 是不是太胖了(5 分)
据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。已知市斤是公斤的两倍。现给定某人身高,请你计算其标准体重应该是多少?(顺便也悄悄给自己算一下吧……)
输入格式:
输入第一行给出一个正整数H
(100 < H ≤ 300),为某人身高。
输出格式:
在一行中输出对应的标准体重,单位为市斤,保留小数点后1位。
输入样例:
169
输出样例:
124.2
7-4 判断素数(10 分)
本题的目标很简单,就是判断一个给定的正整数是否素数。
输入格式:
输入在第一行给出一个正整数N
(≤ 10),随后N
行,每行给出一个小于231的需要判断的正整数。
输出格式:
对每个需要判断的正整数,如果它是素数,则在一行中输出Yes
,否则输出No
。
输入样例:
2
11
111
输出样例:
Yes
No
#include <math.h>
int main(){
int n, i, flag;
long long x;
scanf("%d", &n);
while(n--)
{
scanf("%lld", &x);
flag =1;
for(i = 2; i <= sqrt(x); i++)
{
if(x % i == 0)
{
flag =0;
break;
}
}
if(x == 1 || flag == 0)
printf("No\n");
else
printf("Yes\n");
}
return0;
}
7-7 到底是不是太胖了(10 分)
据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。真实体重与标准体重误差在10%以内都是完美身材(即 | 真实体重 − 标准体重 | < 标准体重×10%)。已知市斤是公斤的两倍。现给定一群人的身高和实际体重,请你告诉他们是否太胖或太瘦了。
输入格式:
输入第一行给出一个正整数N
(≤ 20)。随后N
行,每行给出两个整数,分别是一个人的身高H
(120 < H < 200;单位:厘米)和真实体重W
(50 < W ≤ 300;单位:市斤),其间以空格分隔。
输出格式:
为每个人输出一行结论:如果是完美身材,输出You are wan mei!
;如果太胖了,输出You are tai pang le!
;否则输出You are tai shou le!
。
输入样例:
3
169 136
150 81
178 155
输出样例:
You are wan mei!
You are tai shou le!
You are tai pang le!
#include<math.h>
int n, a, b, c,i,j;
main()
{
scanf("%d", &n);
for (i = 1; i <= n; i++)
{
scanf("%d %d", &a, &b);
c = (a - 100)*1.8;
if (fabs(b - c) < (c*0.1))
{
printf("You are wan mei!\n");
}
if ((fabs(b - c) >= (c*0.1)) && b < c)
{
printf("You are tai shou le!\n");
}
if ((fabs(b - c) >= (c*0.1)) && b > c)
{
printf("You are tai pang le!\n");
}
}
}
7-1 正整数A+B(15 分)
题的目标很简单,就是求两个正整数A
和B
的和,其中A
和B
都在区间[1,1000]。稍微有点麻烦的是,输入并不保证是两个正整数。
输入格式:
输入在一行给出A
和B
,其间以空格分开。问题是A
和B
不一定是满足要求的正整数,有时候可能是超出范围的数字、负数、带小数点的实数、甚至是一堆乱码。
注意:我们把输入中出现的第1个空格认为是A
和B
的分隔。题目保证至少存在一个空格,并且B
不是一个空字符串。
输出格式:
如果输入的确是两个正整数,则按格式A + B = 和
输出。如果某个输入不合要求,则在相应位置输出?
,显然此时和也是?
。
输入样例1:
123 456
输出样例1:
123 + 456 = 579
输入样例2:
22. 18
输出样例2:
? + 18 = ?
输入样例3:
-100 blabla bla...33
输出样例3:
? + ? = ?
#include<stdio.h>
#include<string.h>
#include<iostream>
using namespace std;
int main(){
char a[1001],b[1001];
int c,d;
bool flag1=true;
bool flag2=true;
cin>>a;
scanf(" ");
cin>>b;
int len1=strlen(a);
int len2=strlen(b);
if(len1<1||len1>4)
flag1=false;
else{
for(int i=0;i<len1;i++){
if(a[i]<'0' || a[i]>'9'){
flag1=false;
break;
}
}
}
if(len2<1||len2>4)
flag2=false;
else{
for(int i=0;i<len2;i++){
if(b[i]<'0'||b[i]>'9'){
flag2=false;
break;
}
}
}
if(flag1&&flag2){
c=0;d=0;
for(int i=0;i<len1;i++){
c=c*10+a[i]-'0';
}
for(int i=0;i<len2;i++){
d=d*10+b[i]-'0';
}
if(c<1&&c>1000)
flag1=false;
if(d<1&&d>1000)
flag2=false;
}
if(flag1)
cout<<a<<" ";
else
cout<<"? ";
cout<<"+ ";
if(flag2)
cout<<b<<" ";
else
cout<<"? ";
cout<<"= ";
if(flag1&&flag2)
cout<<c+d;
else
cout<<"?";
}
7-3 谁先倒(15 分)
划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就输了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。
下面给出甲、乙两人的酒量(最多能喝多少杯不倒)和划拳记录,请你判断两个人谁先倒。
输入格式:
输入第一行先后给出甲、乙两人的酒量(不超过100的非负整数),以空格分隔。下一行给出一个正整数N
(≤100),随后N
行,每行给出一轮划拳的记录,格式为:
甲喊 甲划 乙喊 乙划
其中喊
是喊出的数字,划
是划出的数字,均为不超过100的正整数(两只手一起划)。
输出格式:
在第一行中输出先倒下的那个人:A
代表甲,B
代表乙。第二行中输出没倒的那个人喝了多少杯。题目保证有一个人倒下。注意程序处理到有人倒下就终止,后面的数据不必处理。
输入样例:
1 1
6
8 10 9 12
5 10 5 10
3 8 5 12
12 18 1 13
4 16 12 15
15 1 1 16
输出样例:
A
1
int main(){
int a,b;
int n;
scanf("%d%d",&a,&b);
scanf("%d",&n);
int ahan,ahua,bhan,bhua;
int ac=0,bc=0;
while(n--){
scanf("%d%d%d%d",&ahan,&ahua,&bhan,&bhua);
if((ahan+bhan!=ahua && ahan+bhan!=bhua) || (ahan+bhan==ahua && ahan+bhan==bhua)){ //同赢或者同输
continue;
}
else if(ahan+bhan==ahua && ahan+bhan!=bhua){//甲输甲喝
ac++;
}
else if(ahan+bhan==bhua && ahan+bhan!=ahua){//乙输乙喝
bc++;
}
if(ac>a || bc>b){ //任意一个超过酒量倒下的就停止,继续输入下面的数据,但是不处理
while(n--){
scanf("%d%d%d%d",&ahan,&ahua,&bhan,&bhua);