目录
一、胎压监测
小轿车中有一个系统随时监测四个车轮的胎压,如果四轮胎压不是很平衡,则可能对行车造成严重的影响。
让我们把四个车轮 —— 左前轮、右前轮、右后轮、左后轮 —— 顺次编号为 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分的明天再水