PTA团体程序设计天梯赛(L1-061~L1-070)
PTA团体程序设计天梯赛[L1-061~L1-070]
- L1-060 心理阴影面积 (5 分)
- L1-062 幸运彩票 (15 分)
- L1-063 吃鱼还是吃肉 (10 分)
- L1-064 估值一亿的AI核心代码 (20 分)
- L1-065 嫑废话上代码 (5 分)
- L1-066 猫是液体 (5 分)
- L1-067 洛希极限 (10 分)
- L1-068 调和平均 (10 分)
- L1-069 胎压监测 (15 分)
- L1-070 吃火锅 (15 分)
+++点击资源索引【查看其它题目】+++
L1-060 心理阴影面积 (5 分)
xlyy.JPG
这是一幅心理阴影面积图。我们都以为自己可以匀速前进(图中蓝色直线),而拖延症晚期的我们往往执行的是最后时刻的疯狂赶工(图中的红色折线)。由红、蓝线围出的面积,就是我们在做作业时的心理阴影面积。
现给出红色拐点的坐标 (x,y),要求你算出这个心理阴影面积。
输入格式:
输入在一行中给出 2 个不超过 100 的正整数 x 和 y,并且保证有 x>y。这里假设横、纵坐标的最大值(即截止日和最终完成度)都是 100。
输出格式:
在一行中输出心理阴影面积。
友情提醒:三角形的面积 = 底边长 x 高 / 2;矩形面积 = 底边长 x 高。嫑想得太复杂,这是一道 5 分考减法的题……
输入样例:
90 10
结尾无空行
输出样例:
4000
结尾无空行
#include<bits/stdc++.h>
using namespace std; int main()
{double l,w;cin>>w>>l;double n=w/(l*l);printf("%.1f\n",n);if(n>25)printf("PANG\n");else printf("Hai Xing\n");
}
L1-062 幸运彩票 (15 分)
彩票的号码有 6 位数字,若一张彩票的前 3 位上的数之和等于后 3 位上的数之和,则称这张彩票是幸运的。本题就请你判断给定的彩票是不是幸运的。
输入格式:
输入在第一行中给出一个正整数 N(≤ 100)。随后 N 行,每行给出一张彩票的 6 位数字。
输出格式:
对每张彩票,如果它是幸运的,就在一行中输出 You are lucky!;否则输出 Wish you good luck.。
输入样例:
2
233008
123456
结尾无空行
输出样例:
You are lucky!
Wish you good luck.
结尾无空行
#include<bits/stdc++.h>
using namespace std;
int main()
{int n,x;cin>>n;while(n--){cin>>x;int x1=x/1000;int x2=x%1000;int a1=x1%10,a2=x1/10%10,a3=x1/100;int b1=x2%10,b2=x2/10%10,b3=x2/100;if(a1+a2+a3==b1+b2+b3)printf("You are lucky!\n");else printf("Wish you good luck.\n"); }
}
L1-063 吃鱼还是吃肉 (10 分)
fish.JPG 肉.JPG
国家给出了 8 岁男宝宝的标准身高为 130 厘米、标准体重为 27 公斤;8 岁女宝宝的标准身高为 129 厘米、标准体重为 25 公斤。
现在你要根据小宝宝的身高体重,给出补充营养的建议。
输入格式:
输入在第一行给出一个不超过 10 的正整数 N,随后 N 行,每行给出一位宝宝的身体数据:
性别 身高 体重
其中性别是 1 表示男生,0 表示女生。身高和体重都是不超过 200 的正整数。
输出格式:
对于每一位宝宝,在一行中给出你的建议:
如果太矮了,输出:duo chi yu!(多吃鱼);
如果太瘦了,输出:duo chi rou!(多吃肉);
如果正标准,输出:wan mei!(完美);
如果太高了,输出:ni li hai!(你厉害);
如果太胖了,输出:shao chi rou!(少吃肉)。
先评价身高,再评价体重。两句话之间要有 1 个空格。
输入样例:
4
0 130 23
1 129 27
1 130 30
0 128 27
结尾无空行
输出样例:
ni li hai! duo chi rou!
duo chi yu! wan mei!
wan mei! shao chi rou!
duo chi yu! shao chi rou!
结尾无空行
#include<bits/stdc++.h>
using namespace std; int main()
{int n;cin>>n;while(n--){int a,l,w;cin>>a;if(a==0){cin>>l>>w;if(l<129)printf("duo chi yu! ");else if(l==129)printf("wan mei! ");else printf("ni li hai! ");if(w<25)printf("duo chi rou!\n");else if(w==25)printf("wan mei!\n");else printf("shao chi rou!\n");}else {cin>>l>>w;if(l<130)printf("duo chi yu! ");else if(l==130)printf("wan mei! ");else printf("ni li hai! ");if(w<27)printf("duo chi rou!\n");else if(w==27)printf("wan mei!\n");else printf("shao chi rou!\n");}}
}
L1-064 估值一亿的AI核心代码 (20 分)
AI.jpg
以上图片来自新浪微博。
本题要求你实现一个稍微更值钱一点的 AI 英文问答程序,规则是:
无论用户说什么,首先把对方说的话在一行中原样打印出来;
消除原文中多余空格:把相邻单词间的多个空格换成 1 个空格,把行首尾的空格全部删掉,把标点符号前面的空格删掉;
把原文中所有大写英文字母变成小写,除了 I;
把原文中所有独立的 can you、could you 对应地换成 I can、I could—— 这里“独立”是指被空格或标点符号分隔开的单词;
把原文中所有独立的 I 和 me 换成 you;
把原文中所有的问号 ? 换成惊叹号 !;
在一行中输出替换后的句子作为 AI 的回答。
输入格式:
输入首先在第一行给出不超过 10 的正整数 N,随后 N 行,每行给出一句不超过 1000 个字符的、以回车结尾的用户的对话,对话为非空字符串,仅包括字母、数字、空格、可见的半角标点符号。
输出格式:
按题面要求输出,每个 AI 的回答前要加上 AI: 和一个空格。
输入样例:
6
Hello ?
Good to chat with you
can you speak Chinese?
Really?
Could you show me 5
What Is this prime? I,don 't know
结尾无空行
输出样例:
Hello ?
AI: hello!
Good to chat with you
AI: good to chat with you
can you speak Chinese?
AI: I can speak chinese!
Really?
AI: really!
Could you show me 5
AI: I could show you 5
What Is this prime? I,don 't know
AI: what Is this prime! you,don’t know
#include<iostream>
#include<string>using namespace std;int judge(char c)
{if (c >= 'A'&&c <= 'Z') return 1;if (c >= 'a'&&c <= 'z') return 2;if (c >= '0'&&c <= '9') return 3;if (c == ' ') return -1; return 0; //标点符号
}
/*
思路:循环两次1.第一个循环,
A.多个空格留一个,标点符号前无空格
B.把所有大写字母变成小写,除了I;
C.?变成 !2.第一次循环后,如果行首存在空格,把空格消除3.第二个循环,替换原文的"i can","I could","I,"me"
*/int main()
{int m;cin>>m; getchar();while(m--){string s,str;getline(cin,s);cout<< s << endl;//对s[i]进行的操作for (int i = 0; s[i]; i++){//注意空格表示方法是‘ ’if(s[i]==' '&&judge(s[i+1])<=0) //多个空格的话,只留下一个空格 和 消除标点符号前的空格 continue;if(judge(s[i])==1&& s[i]!='I')//将大写英文字母改为小写,除了Is[i]=tolower(s[i]);if (s[i] == '?') s[i] = '!';str += s[i];}if(str[0]==' ')str = str.substr(1); //如果开头是空格,消除他 string temp;//中间变量,进行比较s = str;str ="";//初始化返回答案for(int i = 0; i < s.size(); i++){//独立的前提//i-1是空格或标点符号,则对i进行截取(因为这是一个单词的开始)if(judge(s[i-1])<=0){//独立的后提//temp="替换单词"&&替换单词后一个字符为空格或标点符号temp = s.substr(i,7); //替换can you if(temp == "can you" && judge(s[i+7])<=0){str += "I can";i += 7;}temp = s.substr(i,9); //替换could you if(temp == "could you" && judge(s[i+9])<=0) {str += "I could";i += 9;}temp = s.substr(i,1);if(temp == "I" && judge(s[i+1])<=0) //替换 I {str += "you";i += 1;}temp = s.substr(i,2); //替换me if(temp == "me" && judge(s[i+2])<=0){str += "you";i += 2;}}//不明白为什么要if判断if(i < s.size()) //如果不是以上替换单词,那么就str += s[i];}cout<<"AI: "<<str<<endl;}
}
L1-065 嫑废话上代码 (5 分)
Linux 之父 Linus Torvalds 的名言是:“Talk is cheap. Show me the code.”(嫑废话,上代码)。本题就请你直接在屏幕上输出这句话。
输入格式:
本题没有输入。
输出格式:
在一行中输出 Talk is cheap. Show me the code.。
输入样例:
无
结尾无空行
输出样例:
Talk is cheap. Show me the code.
结尾无空行
print("Talk is cheap. Show me the code.")
L1-066 猫是液体 (5 分)
cat.JPG
测量一个人的体积是很难的,但猫就不一样了。因为猫是液体,所以可以很容易地通过测量一个长方体容器的容积来得到容器里猫的体积。本题就请你完成这个计算。
输入格式:
输入在第一行中给出 3 个不超过 100 的正整数,分别对应容器的长、宽、高。
输出格式:
在一行中输出猫的体积。
输入样例:
23 15 20
结尾无空行
输出样例:
6900
结尾无空行
#include<bits/stdc++.h>
using namespace std; int main()
{int a,b,c;cin>>a>>b>>c;printf("%d\n",a*b*c);
}
L1-067 洛希极限 (10 分)
科幻电影《流浪地球》中一个重要的情节是地球距离木星太近时,大气开始被木星吸走,而随着不断接近地木“刚体洛希极限”,地球面临被彻底撕碎的危险。但实际上,这个计算是错误的。
roche.jpg
洛希极限(Roche limit)是一个天体自身的引力与第二个天体造成的潮汐力相等时的距离。当两个天体的距离少于洛希极限,天体就会倾向碎散,继而成为第二个天体的环。它以首位计算这个极限的人爱德华·洛希命名。(摘自百度百科)
大天体密度与小天体的密度的比值开 3 次方后,再乘以大天体的半径以及一个倍数(流体对应的倍数是 2.455,刚体对应的倍数是 1.26),就是洛希极限的值。例如木星与地球的密度比值开 3 次方是 0.622,如果假设地球是流体,那么洛希极限就是 0.622×2.455=1.52701 倍木星半径;但地球是刚体,对应的洛希极限是 0.622×1.26=0.78372 倍木星半径,这个距离比木星半径小,即只有当地球位于木星内部的时候才会被撕碎,换言之,就是地球不可能被撕碎。
本题就请你判断一个小天体会不会被一个大天体撕碎。
输入格式:
输入在一行中给出 3 个数字,依次为:大天体密度与小天体的密度的比值开 3 次方后计算出的值(≤1)、小天体的属性(0 表示流体、1 表示刚体)、两个天体的距离与大天体半径的比值(>1 但不超过 10)。
输出格式:
在一行中首先输出小天体的洛希极限与大天体半径的比值(输出小数点后2位);随后空一格;最后输出 _ 如果小天体不会被撕碎,否则输出 T_T。
输入样例 1:
0.622 0 1.4
结尾无空行
输出样例 1:
1.53 T_T
结尾无空行
输入样例 2:
0.622 1 1.4
结尾无空行
输出样例 2:
0.78 _
结尾无空行
#include<iostream>
using namespace std;int main() {double a,c;int b;double x,y;cin>>a>>b>>c;if(b==0)x=2.455*a;else if(b==1)x=1.26*a;if(x<c)printf("%.2f ^_^",x);elseprintf("%.2f T_T",x);return 0;
}
L1-068 调和平均 (10 分)
N 个正数的算数平均是这些数的和除以 N,它们的调和平均是它们倒数的算数平均的倒数。本题就请你计算给定的一系列正数的调和平均值。
输入格式:
每个输入包含 1 个测试用例。每个测试用例第 1 行给出正整数 N (≤1000);第 2 行给出 N 个正数,都在区间 [0.1,100] 内。
输出格式:
在一行中输出给定数列的调和平均值,输出小数点后2位。
输入样例:
8
10 15 12.7 0.3 4 13 1 15.6
结尾无空行
输出样例:
1.61
结尾无空行
#include<bits/stdc++.h>
using namespace std; int main()
{int n;double x,sum=0;cin>>n;int t=n;while(n--){cin>>x;sum+=1.0/x;}printf("%.2f",t/sum);
}
L1-069 胎压监测 (15 分)
小轿车中有一个系统随时监测四个车轮的胎压,如果四轮胎压不是很平衡,则可能对行车造成严重的影响。
taiya.JPG
让我们把四个车轮 —— 左前轮、右前轮、右后轮、左后轮 —— 顺次编号为 1、2、3、4。本题就请你编写一个监测程序,随时监测四轮的胎压,并给出正确的报警信息。报警规则如下:
如果所有轮胎的压力值与它们中的最大值误差在一个给定阈值内,并且都不低于系统设定的最低报警胎压,则说明情况正常,不报警;
如果存在一个轮胎的压力值与它们中的最大值误差超过了阈值,或者低于系统设定的最低报警胎压,则不仅要报警,而且要给出可能漏气的轮胎的准确位置;
如果存在两个或两个以上轮胎的压力值与它们中的最大值误差超过了阈值,或者低于系统设定的最低报警胎压,则报警要求检查所有轮胎。
输入格式:
输入在一行中给出 6 个 [0, 400] 范围内的整数,依次为 1~4 号轮胎的胎压、最低报警胎压、以及胎压差的阈值。
输出格式:
根据输入的胎压值给出对应信息:
如果不用报警,输出 Normal;
如果有一个轮胎需要报警,输出 Warning: please check #X!,其中 X 是出问题的轮胎的编号;
如果需要检查所有轮胎,输出 Warning: please check all the tires!。
输入样例 1:
242 251 231 248 230 20
结尾无空行
输出样例 1:
Normal
结尾无空行
输入样例 2:
242 251 232 248 230 10
结尾无空行
输出样例 2:
Warning: please check #3!
结尾无空行
输入样例 3:
240 251 232 248 240 10
结尾无空行
输出样例 3:
Warning: please check all the tires!
结尾无空行
//某个测试点错误
/*#include<bits/stdc++.h>
using namespace std;int main()
{int a[7],c=0,t,x,b=-1;for(int i=1;i<=6;i++){cin>>a[i];b=max(b,a[i]);}if((a[1]<a[5])||(fabs(a[1]-b)>a[6])){c++;if(c==1)t=1;}else if((a[2]<a[5])||(fabs(a[2]-b)>a[6])){c++;if(c==1)t=2;}else if((a[3]<a[5])||(fabs(a[3]-b)>a[6])){c++;if(c==1)t=3;}else if((a[4]<a[5])||(fabs(a[4]-b)>a[6])){c++;if(c==1)t=4;}if(c==0)printf("Normal\n");else if(c==1)printf("Warning: please check #%d!\n",t);else printf("Warning: please check all the tires!\n");return 0;
} */#include<bits/stdc++.h>
using namespace std;
int main()
{int a[10], bj, yz;int mx=-1;for(int i=1;i<=4;i++){cin>>a[i];mx=max(mx,a[i]);}cin>>bj>>yz;int ok = 1, lq;for(int i = 1; i <= 4; i++){if(mx-a[i]>yz || a[i]<bj){if(ok==1)ok=0;//成立一次 0else ok = 2; //成立多次 2lq = i;//成立1次,记录车胎;成立多次,无任何作用}}if(ok==1)cout<<"Normal\n"; //0else if(ok==0)cout<<"Warning: please check #"<<lq<<"!\n"; //1else cout<<"Warning: please check all the tires!\n"; //2,3,4return 0;
}
L1-070 吃火锅 (15 分)
chg.jpg
以上图片来自微信朋友圈:这种天气你有什么破事打电话给我基本没用。但是如果你说“吃火锅”,那就厉害了,我们的故事就开始了。
本题要求你实现一个程序,自动检查你朋友给你发来的信息里有没有 chi1 huo3 guo1。
输入格式:
输入每行给出一句不超过 80 个字符的、以回车结尾的朋友信息,信息为非空字符串,仅包括字母、数字、空格、可见的半角标点符号。当读到某一行只有一个英文句点 . 时,输入结束,此行不算在朋友信息里。
输出格式:
首先在一行中输出朋友信息的总条数。然后对朋友的每一行信息,检查其中是否包含 chi1 huo3 guo1,并且统计这样厉害的信息有多少条。在第二行中首先输出第一次出现 chi1 huo3 guo1 的信息是第几条(从 1 开始计数),然后输出这类信息的总条数,其间以一个空格分隔。题目保证输出的所有数字不超过 100。
如果朋友从头到尾都没提 chi1 huo3 guo1 这个关键词,则在第二行输出一个表情 -_-#。
输入样例 1:
Hello!
are you there?
wantta chi1 huo3 guo1?
that’s so li hai le
our story begins from chi1 huo3 guo1 le
.
结尾无空行
输出样例 1:
5
3 2
结尾无空行
输入样例 2:
Hello!
are you there?
wantta qi huo3 guo1 chi1huo3guo1?
that’s so li hai le
our story begins from ci1 huo4 guo2 le
.
结尾无空行
输出样例 2:
5
-_-#
结尾无空行
#include<bits/stdc++.h>
using namespace std;
int main()
{//i定义总共的语句数量,n定义"吃火锅"出现多少次,t定义第一次出现"吃火锅"是第几条信息,flog记录是否有该字符串int n=0,i=0,t=0,flog=0;string s;while(getline(cin,s)&&s!="."){i++;if(s.find("chi1 huo3 guo1")!=-1){flog=1;if(n==0)t=i;n++;}}if(flog==1){printf("%d\n",i);printf("%d %d\n",t,n);}else{printf("%d\n",i);printf("-_-#\n");}
} /*#include<bits/stdc++.h>
using namespace std;
int main()
{//a定义总共的语句数量,b定义"吃火锅"出现多少次,c定义第一次出现"吃火锅"是第几条信息。int a=0,b=0,c;string s;while(getline(cin,s)&&s!=".")//一行一行读入,且判断是否可以继续读入{a++;if(s.find("chi1 huo3 guo1")!=-1){if(!b) c=a;b++;}}cout<<a<<endl;if(b)cout<<c<<" "<<b<<endl;elsecout<<"-_-#"<<endl;return 0;
}
*/
PTA团体程序设计天梯赛(L1-061~L1-070)相关推荐
- 【CCCC】PAT : 团体程序设计天梯赛-练习集 L1 答案
[CCCC]PAT : 团体程序设计天梯赛-练习集 L1 答案 鉴定完毕,全部水题 ヾ(•ω•`)o 标号 标题 分数 通过数 提交数 通过率 L1-001 Hello World 5 46779 1 ...
- PTA团体程序设计天梯赛篇(五)---- 难题篇一(30分题目)
PTA团体程序设计天梯赛 数据结构类型 L3-002 特殊堆栈(树状数组) L3-003 社交集群(并查集) 搜索 L3-004 肿瘤诊断(三维bfs) 确保bfs只遍历一次的方法 图论 L3-005 ...
- PTA团体程序设计天梯赛-练习集(3)
PTA团体程序设计天梯赛-练习集 L1-001 Hello World (5 分) 这道超级简单的题目没有任何输入. 你只需要在一行中输出著名短句"Hello World!"就可以 ...
- PTA团体程序设计天梯赛-练习集
PTA团体程序设计天梯赛-练习集 L1-024 后天 L1-025 正整数A+B L1-026 I Love GPLT L1-027 出租 L1-029 是不是太胖了 L1-030 一帮一 L1-03 ...
- PTA|团体程序设计天梯赛-练习题目题解锦集(C/C++)(持续更新中……)
PTA|团体程序设计天梯赛-练习题目题解锦集(持续更新中) 实现语言:C/C++: 欢迎各位看官交流讨论.指导题解错误:或者分享更快的方法!! 题目链接:https://pintia.cn/ ...
- PTA团体程序设计天梯赛-练习集Level-1(参考代码C语言/Python版)
本题目集截止到2022年天梯赛 受个人水平限制,<PTA团体程序设计天梯赛-练习集>中暂时只能把Level-1的题目做出来(也许有些Level-2的题可以写出来?)-我不是专门搞竞赛的,参 ...
- PTA团体程序设计天梯赛(L1-031~L1-040)
PTA团体程序设计天梯赛[L1-031~L1-040] L1-031 到底是不是太胖了 (10 分) L1-032 Left-pad (20 分) L1-033 出生年 (15 分) L1-034 点 ...
- PTA|团体程序设计天梯赛-练习题库集
文章目录 关于爬取脚本的编写 L1-001 Hello World! (5 分) L1-002 打印沙漏 (15 分) L1-003 个位数统计 (15 分) L1-004 计算摄氏温度 (5 分) ...
- 团体程序设计天梯赛 -- 练习集 (L1合集)
文章目录 L1-001 Hello World (5 分) L1-002 打印沙漏 (20 分) L1-003 个位数统计 (15 分) L1-004 计算摄氏温度 (5 分) L1-005 考试座位 ...
最新文章
- CIO职能向流程演进
- MySQL优化学习总结
- TF:基于CNN(2+1)实现MNIST手写数字图片识别准确率提高到99%
- SRS流媒体服务器——单机环境搭建和源码目录介绍
- android layerlist bitmap,android shape类似的 另一个 高端用法:layer-list
- rdd转换成java数据结构_Spark RDD转换成其他数据结构
- Java 多线程 - 线程 - 守护线程
- pythonmatplotlib绘图小提琴_使用seaborn制图(小提琴图)
- 教你搭建一个NAT实验环境
- Java的Socket编程C/S小例子
- 通信原理包络是什么意思_自己总结的通信原理部分知识点
- 毕设论文指导--yolov5汽车识别
- 关于城市智慧道路建设的思考
- ad转3d视图快捷键_AD详细快捷键按键
- android英雄无敌 中文版下载地址,英雄无敌3手机版
- 在线数据迁移,数字化时代的必修课——京东云数据迁移实践
- 通信工程测试图修改软件,通信工程工具仪器大全,你用过几种?
- 年底裁员潮,这个冬天你怎样度过?
- 工具篇:TailScale免费实现远程设备互连(无费用方案,亲测,零基础安装),支持手机、Windows或linux系统、NAS
- EventEmitter has used unknown event type: “pullingUp“, should be oneof