PTA2017年天梯赛题目整理

题目按分数值递增

A乘以B(5 分)

看我没骗你吧 —— 这是一道你可以在10秒内完成的题:给定两个绝对值不超过100的整数AB,输出A乘以B的值。

输入格式:

输入在第一行给出两个整数AB100A,B100),数字间以空格分隔。

输出格式:

在一行中输出A乘以B的值。

输入样例:

-8 13

输出样例:

-104



7-6 新世界(5 分)

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

你只需要在第一行中输出程序员钦定名言“Hello World”,并且在第二行中输出更新版的“Hello New World”就可以了。




L1-2 日期格式化(5 分)

世界上不同国家有不同的写日期的习惯。比如美国人习惯写成“月-日-年”,而中国人习惯写成“年-月-日”。下面请你写个程序,自动把读入的美国格式的日期改写成中国习惯的日期。

输入格式:

输入在一行中按照“mm-dd-yyyy”的格式给出月、日、年。题目保证给出的日期是1900年元旦至今合法的日期。

输出格式:

在一行中按照“yyyy-mm-dd”的格式给出年、月、日。

输入样例:

03-15-2017

输出样例:

2017-03-15
三个数字换个样子输出,但是要注意如果月份和日不满足两位的时候,只用%d输出数字,数字前的0会自动消除,所以需要规范月和日的输出格式,即用%02d输出。



L1-5 宇宙无敌大招呼(5 分)

据说所有程序员学习的第一个程序都是在屏幕上输出一句“Hello World”,跟这个世界打个招呼。作为天梯赛中的程序员,你写的程序得高级一点,要能跟任意指定的星球打招呼。

输入格式:

输入在第一行给出一个星球的名字S,是一个由不超过7个英文字母组成的单词,以回车结束。

输出格式:

在一行中输出Hello S,跟输入的S星球打个招呼。

输入样例:

Mars

输出样例:

Hello Mars



7-5 A除以B(10 分)

真的是简单题哈 —— 给定两个绝对值不超过100的整数AB,要求你按照“A/B=商”的格式输出结果。

输入格式:

输入在第一行给出两个整数AB100A,B100),数字间以空格分隔。

输出格式:

在一行中输出结果:如果分母是正数,则输出“A/B=商”;如果分母是负数,则要用括号把分母括起来输出;如果分母为零,则输出的商应为Error。输出的商应保留小数点后2位。

输入样例1:

-1 2

输出样例1:

-1/2=-0.50

输入样例2:

1 -3

输出样例2:

1/(-3)=-0.33

输入样例3:

5 0

输出样例3:

5/0=Error
#include<stdio.h>
int main(){
int a,b;
double c;
while(scanf("%d%d",&a,&b)!=EOF){
if(b==0){
printf("%d/%d=Error\n",a,b);
}
else if(b<0){
c=(double)a/b;
printf("%d/(%d)=%.2lf\n",a,b,c);
}
else{
c=(double)a/b;
printf("%d/%d=%.2lf\n",a,b,c);
}
}
}



7-8 最佳情侣身高差(10 分)

专家通过多组情侣研究数据发现,最佳的情侣身高差遵循着一个公式:(女方的身高)×1.09 =(男方的身高)。如果符合,你俩的身高差不管是牵手、拥抱、接吻,都是最和谐的差度。

下面就请你写个程序,为任意一位用户计算他/她的情侣的最佳身高。

输入格式:

输入第一行给出正整数N10),为前来查询的用户数。随后N行,每行按照“性别 身高”的格式给出前来查询的用户的性别和身高,其中“性别”为“F”表示女性、“M”表示男性;“身高”为区间 [1.0, 3.0] 之间的实数。

输出格式:

对每一个查询,在一行中为该用户计算出其情侣的最佳身高,保留小数点后2位。

输入样例:

2
M 1.75
F 1.8

输出样例:

1.61
1.96
#include<stdio.h>
int main(){
int n;
scanf("%d",&n);
char sex;
double h;
double h1;
for(int i=0;i<n;i++){
scanf(" %c %lf",&sex,&h);
if(sex=='M'){
h1=h/1.09;
printf("%.2lf\n",h1);
}
if(sex=='F'){
h1=h*1.09;
printf("%.2lf\n",h1);
}
}
}



L1-1 寻找250(10 分)

对方不想和你说话,并向你扔了一串数…… 而你必须从这一串数字中找到“250”这个高大上的感人数字。

输入格式:

输入在一行中给出不知道多少个绝对值不超过1000的整数,其中保证至少存在一个“250”。

输出格式:

在一行中输出第一次出现的“250”是对方扔过来的第几个数字(计数从1开始)。题目保证输出的数字在整型范围内。

输入样例:

888 666 123 -233 250 13 250 -222

输出样例:

5
#include<iostream>
#include<stdio.h>
using namespace std;
int main()
{
char a[10];
int count=1;
int flag=0;
int x;
while(scanf("%s",a)!=EOF){    //a代表的是一个字符数组的首地址,也是一个字符串的首地址

//scanf()输入不吃回车 即假如输入123 456   %s输出后只出123 
if(a[0]=='2'&&a[1]=='5'&&a[2]=='0'&&flag==0){
x=count;
flag=1;
}
count++;
}
printf("%d\n",x);
}




L1-7 装睡(10 分)

你永远叫不醒一个装睡的人 —— 但是通过分析一个人的呼吸频率和脉搏,你可以发现谁在装睡!医生告诉我们,正常人睡眠时的呼吸频率是每分钟15-20次,脉搏是每分钟50-70次。下面给定一系列人的呼吸频率与脉搏,请你找出他们中间有可能在装睡的人,即至少一项指标不在正常范围内的人。

输入格式:

输入在第一行给出一个正整数N10)。随后N行,每行给出一个人的名字(仅由英文字母组成的、长度不超过3个字符的串)、其呼吸频率和脉搏(均为不超过100的正整数)。

输出格式:

按照输入顺序检查每个人,如果其至少一项指标不在正常范围内,则输出其名字,每个名字占一行。

输入样例:

4
Amy 15 70
Tom 14 60
Joe 18 50
Zoe 21 71

输出样例:

Tom
Zoe
#include<stdio.h>
#include<iostream>
using namespace std;
struct People{
string name;
int hx;
int mb;
}people;
int main()
{
int n;
scanf("%d",&n);
while(n--){
cin>>people.name>>people.hx>>people.mb;
if((people.hx<15||people.hx>20)||(people.mb<50||people.mb>70)){
cout<<people.name<<endl;
}
}
}




7-3 情人节(15 分)

以上是朋友圈中一奇葩贴:“2月14情人节了,我决定造福大家。第2个赞和第14个赞的,我介绍你俩认识…………咱三吃饭…你俩请…”。现给出此贴下点赞的朋友名单,请你找出那两位要请客的倒霉蛋。

输入格式:

输入按照点赞的先后顺序给出不知道多少个点赞的人名,每个人名占一行,为不超过10个英文字母的非空单词,以回车结束。一个英文句点.标志输入的结束,这个符号不算在点赞名单里。

输出格式:

根据点赞情况在一行中输出结论:若存在第2个人A和第14个人B,则输出“A and B are inviting you to dinner...”;若只有A没有B,则输出“A is the only one for you...”;若连A都没有,则输出“Momo... No one is for you ...”。

输入样例1:

GaoXZh
Magi
Einst
Quark
LaoLao
FatMouse
ZhaShen
fantacy
latesum
SenSen
QuanQuan
whatever
whenever
Potaty
hahaha
.

输出样例1:

Magi and Potaty are inviting you to dinner...

输入样例2:

LaoLao
FatMouse
whoever
.

输出样例2:

FatMouse is the only one for you...

输入样例3:

LaoLao
.

输出样例3:

Momo... No one is for you ...
#include<stdio.h>
int main(){
int i;
char name[16][11];
for(i=0;i<=15;i++){
scanf("%s",name[i]);
if(name[i][0]=='.')
break;
}
    if ( i - 1 < 2 )  
        printf("Momo... No one is for you ...");  
    else if ( i - 1 < 14 )  
        printf("%s is the only one for you...", name[1]);  
    else  
        printf("%s and %s are inviting you to dinner...", name[1], name[13]);  
    return 0;  
}



7-1 出生年(15 分)

以上是新浪微博中一奇葩贴:“我出生于1988年,直到25岁才遇到4个数字都不相同的年份。”也就是说,直到2013年才达到“4个数字都不相同”的要求。本题请你根据要求,自动填充“我出生于y年,直到x岁才遇到n个数字都不相同的年份”这句话。

输入格式:

输入在一行中给出出生年份y和目标年份中不同数字的个数n,其中y在[1, 3000]之间,n可以是2、或3、或4。注意不足4位的年份要在前面补零,例如公元1年被认为是0001年,有2个不同的数字0和1。

输出格式:

根据输入,输出x和能达到要求的年份。数字间以1个空格分隔,行首尾不得有多余空格。年份要按4位输出。注意:所谓“n个数字都不相同”是指不同的数字正好是n个。如“2013”被视为满足“4位数字都不同”的条件,但不被视为满足2位或3位数字不同的条件。

输入样例1:

1988 4

输出样例1:

25 2013

输入样例2:

1 2

输出样例2:

0 0001
#include<stdio.h>
#include<string.h>
int main()
{   
  int y,n;
  int a,b,c,d;
  int f[10];
  int leijia=0;
  scanf("%d %d",&y,&n);
  for(int i=y;i<10000;i++)
  {
    a=i/1000;
    b=i/100%10;
    c=i%100/10;
    d=i%10;
    memset(f,0,sizeof(f));
    f[a]=1;
    if(f[b]!=1)
    f[b]=1;
    if(f[c]!=1)
    f[c]=1;
    if(f[d]!=1)
    f[d]=1;
    int sum=0;
    for(int j=0;j<10;j++)
    {
      sum=sum+f[j];
    }
    if(sum==n&&leijia==0)
    {
      printf("%d %04d",i-y,i);
      leijia++;
    }
  }
  return 0;

}




L1-4 稳赢(15 分)

大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:

现要求你编写一个稳赢不输的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方输得太惨,你需要每隔K次就让一个平局。

输入格式:

输入首先在第一行给出正整数K10),即平局间隔的次数。随后每行给出对方的一次出招:ChuiZi代表“锤子”、JianDao代表“剪刀”、Bu代表“布”。End代表输入结束,这一行不要作为出招处理。

输出格式:

对每一个输入的出招,按要求输出稳赢或平局的招式。每招占一行。

输入样例:

2
ChuiZi
JianDao
Bu
JianDao
Bu
ChuiZi
ChuiZi
End

输出样例:

Bu
ChuiZi
Bu
ChuiZi
JianDao
ChuiZi
Bu
#include<stdio.h>
#include<string.h>
#include<iostream>
using namespace std;
int main()
{
int k;
scanf("%d",&k);
string name;
int i=0;
cin>>name;
while(name!="End"){
        if(i == k){
            i = -1;
            cout <<name<< endl;
        }
else if(name=="Bu")
printf("JianDao\n");
else if(name=="ChuiZi")
printf("Bu\n");
else if(name=="JianDao")
printf("ChuiZi\n");
cin>>name;
i++;
}
}




L1-8 矩阵A乘以B(15 分)

给定两个矩阵AB,要求你计算它们的乘积矩阵AB。需要注意的是,只有规模匹配的矩阵才可以相乘。即若ARa行、Ca列,BRb行、Cb列,则只有CaRb相等时,两个矩阵才能相乘。

输入格式:

输入先后给出两个矩阵AB。对于每个矩阵,首先在一行中给出其行数R和列数C,随后

  • 4
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值