PTA练习题-胎压监测、斯德哥尔摩火车上的题、幸运彩票(15分)

目录

一、胎压监测

输入格式:

输出格式:

输入样例 1:

输出样例 1:

输入样例 2:

输出样例 2:

输入样例 3:

输出样例 3:

最终代码: 

 二、斯德哥尔摩火车上的题

输入格式:

输出格式:

输入样例 1:

输出样例 1:

输入样例 2:

输出样例 2:

 最终代码:

 三、幸运彩票

输入格式:

输出格式:

输入样例:

输出样例:

最终代码: 


一、胎压监测

小轿车中有一个系统随时监测四个车轮的胎压,如果四轮胎压不是很平衡,则可能对行车造成严重的影响。

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,b,c,d,miny,maxy;
	cin>>a>>b>>c>>d>>miny>>maxy;
	int ar[4] ;
	ar[0]=a;
	ar[1]=b;
	ar[2]=c;
	ar[3]=d;;
	int smaxy = max(max(c,d),max(a,b));
	int flag = 0;
	int tag=-1;
	 for(int i=0;i<4;i++){
	 	
	 	int cha = abs(ar[i]-smaxy);
	 	if(cha>maxy||ar[i]<miny){
	 		flag++;
			tag=i+1;
		 }
		}
	if(flag==0){
		cout<<"Normal"<<endl;
	}
	else if(flag>=2){
		cout<<"Warning: please check all the tires!"<<endl;
	}
	else{
		cout<<"Warning: please check #"<<tag<<"!"<<endl;
	}
	
	return 0;
}

 二、斯德哥尔摩火车上的题

 

上图是新浪微博上的一则趣闻,是瑞典斯德哥尔摩火车上的一道题,看上去是段伪代码:

s = ''
a = '1112031584'
for (i = 1; i < length(a); i++) {
  if (a[i] % 2 == a[i-1] % 2) {
    s += max(a[i], a[i-1])
  }
}
goto_url('www.multisoft.se/' + s)

其中字符串的 + 操作是连接两个字符串的意思。所以这道题其实是让大家访问网站 www.multisoft.se/112358注意:比赛中千万不要访问这个网址!!!)。

当然,能通过上述算法得到 112358 的原始字符串 a 是不唯一的。本题就请你判断,两个给定的原始字符串,能否通过上述算法得到相同的输出?

输入格式:

输入为两行仅由数字组成的非空字符串,长度均不超过 104,以回车结束。

输出格式:

对两个字符串分别采用上述斯德哥尔摩火车上的算法进行处理。如果两个结果是一样的,则在一行中输出那个结果;否则分别输出各自对应的处理结果,每个占一行。题目保证输出结果不为空。

输入样例 1:

1112031584
011102315849

输出样例 1:

112358

输入样例 2:

111203158412334
12341112031584

输出样例 2:

1123583
112358

 最终代码:

#include<bits/stdc++.h>

using namespace std;

string cal(string s){
	
	string res ="";
	for(int i=1;i<s.size();i++){
		if((s[i]-48)%2 == (s[i-1]-48)%2){
			if(s[i]>s[i-1]){
				res+=s[i];
			}
			else{
				res+=s[i-1];
			}
		}
	}
	return res;
	
}

int main(){
	string s1,s2;
	cin>>s1>>s2;
	
	s1 = cal(s1);
	s2 = cal(s2);
	if(s1==s2){
		cout<<s1;
	}
	else{
		cout<<s1<<endl<<s2<<endl;
	}
	
	return 0;
}

 三、幸运彩票

彩票的号码有 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;

bool cal(string s){
	
	int res1,res2;
	res1=res2=0;
	
	for(int i=0;i<3;i++){
		res1+=s[i]-48;
	}
	for(int i=3;i<6;i++){
		res2+=s[i]-48;
	}
	return res1==res2;
}

int main(){
	int n;
	cin>>n;
	while(n--){
		string s;
		cin>>s;
		
		if(cal(s)){
			cout<<"You are lucky!"<<endl;
		}
		else{
			cout<<"Wish you good luck."<<endl;
		}
	}
	
	return 0;
}

20分的明天再水 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

像污秽一样

谢谢谢谢谢谢谢谢谢谢谢谢

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值