PTA2016年天梯赛题目整理

题目按分数值递增

简单题仅贴思路和关键代码
7-2 I Love GPLT(5 分)

这道超级简单的题目没有任何输入。

你只需要把这句很重要的话 —— I Love GPLT ——竖着输出就可以了。

所谓“竖着输出”,是指每个字符占一行(包括空格),即每行只能有1个字符和回车

printf("I\n"); printf(" \n");



7-5 是不是太胖了(5 分)

据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。已知市斤是公斤的两倍。现给定某人身高,请你计算其标准体重应该是多少?(顺便也悄悄给自己算一下吧……)

输入格式:

输入第一行给出一个正整数H(100 < H  300),为某人身高。

输出格式:

在一行中输出对应的标准体重,单位为市斤,保留小数点后1位。

输入样例:

169

输出样例:

124.2
wight = (h-100)*0.9*2;




7-4 判断素数(10 分)

本题的目标很简单,就是判断一个给定的正整数是否素数。

输入格式:

输入在第一行给出一个正整数N 10),随后N行,每行给出一个小于231的需要判断的正整数。

输出格式:

对每个需要判断的正整数,如果它是素数,则在一行中输出Yes,否则输出No

输入样例:

2
11
111

输出样例:

Yes
No
#include <stdio.h>
#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;
}
//素数:除1以外只能被其自身整除,注意1不是素数,2是素数



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<stdio.h>
#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 分)

题的目标很简单,就是求两个正整数AB的和,其中AB都在区间[1,1000]。稍微有点麻烦的是,输入并不保证是两个正整数。

输入格式:

输入在一行给出AB,其间以空格分开。问题是AB不一定是满足要求的正整数,有时候可能是超出范围的数字、负数、带小数点的实数、甚至是一堆乱码。

注意:我们把输入中出现的第1个空格认为是AB的分隔。题目保证至少存在一个空格,并且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的非负整数),以空格分隔。下一行给出一个正整数N100),随后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
#include<stdio.h>
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);
  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值