1014 福尔摩斯的约会 (20分)
大侦探福尔摩斯接到一张奇怪的字条:我们约会吧!3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm
。大侦探很快就明白了,字条上奇怪的乱码实际上就是约会的时间星期四 14:04
,因为前面两字符串中第 1 对相同的大写英文字母(大小写有区分)是第 4 个字母D
,代表星期四;第 2 对相同的字符是E
,那是第 5 个英文字母,代表一天里的第 14 个钟头(于是一天的 0 点到 23 点由数字 0 到 9、以及大写字母A
到N
表示);后面两字符串第 1 对相同的英文字母s
出现在第 4 个位置(从 0 开始计数)上,代表第 4 分钟。现给定两对字符串,请帮助福尔摩斯解码得到约会的时间。
输入格式:
输入在 4 行中分别给出 4 个非空、不包含空格、且长度不超过 60 的字符串。
输出格式:
在一行中输出约会的时间,格式为DAY HH:MM
,其中DAY
是某星期的 3 字符缩写,即MON
表示星期一,TUE
表示星期二,WED
表示星期三,THU
表示星期四,FRI
表示星期五,SAT
表示星期六,SUN
表示星期日。题目输入保证每个测试存在唯一解。
输入样例:
3485djDkxh4hhGE
2984akDfkkkkggEdsb
s&hgsfdk
d&Hyscvnm
输出样例:
THU 14:04
题目解析:
第一行和第二行第一对相同的英文字母,且满足在A-G之间,输出相应的星期
第一行和第二行第二对相同的字母,且满足0-9之间或者A-N之间输出相应的小时,如果<9的话前面还得加个0,比如 THU 09:33
根据题目给的输入样例可以推断出,第二对相同的英文字母在第一对的后面,所以应该找到第一对相同的英文字母下标,再在此下标后面寻找第二对相同的字母
第三行和第四行相同的第一对英文字母,可以是大写也可以是小写,找完就可以退出循环了,因为只需要找第一对,防止后面还有重复的,然后重复输出。
AC代码:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner s=new Scanner(System.in);
//line几就代表第几行,都转换为字符数组,
char[] line1=s.nextLine().toCharArray();
char[] line2=s.nextLine().toCharArray();
char[] line3=s.nextLine().toCharArray();
char[] line4=s.nextLine().toCharArray();
boolean flag=true;//定义flag的作用就是当找到第一对英文字母之后,置flag=false,然后找第二对
for(int i=0;i<line1.length;i++){
//flag还是true的时候说明正在找第一对英文字母
if(flag){
//第一对满足的条件
if(line1[i]==line2[i]&&line1[i]>='A'&&line1[i]<='G'){
flag=false;//找到之后置flag=false
switch (line1[i]){
case 'A':System.out.print("MON ");break;
case 'B':System.out.print("TUE ");break;
case 'C':System.out.print("WED ");break;
case 'D':System.out.print("THU ");break;
case 'E':System.out.print("FRI ");break;
case 'F':System.out.print("SAT ");break;
case 'G':System.out.print("SUN ");break;
}
}
}else{//执行else时,flag=false,就开始寻找第二对字符
//第二对字符满足的条件
if(line1[i]==line2[i]&&((line1[i]>='0'&&line1[i]<='9')||(line1[i]>='A'&&line1[i]<='N'))){
switch (line1[i]){
case '0':System.out.print("00:");break;
case '1':System.out.print("01:");break;
case '2':System.out.print("02:");break;
case '3':System.out.print("03:");break;
case '4':System.out.print("04:");break;
case '5':System.out.print("05:");break;
case '6':System.out.print("06:");break;
case '7':System.out.print("07:");break;
case '8':System.out.print("08:");break;
case '9':System.out.print("09:");break;
case 'A':System.out.print("10:");break;
case 'B':System.out.print("11:");break;
case 'C':System.out.print("12:");break;
case 'D':System.out.print("13:");break;
case 'E':System.out.print("14:");break;
case 'F':System.out.print("15:");break;
case 'G':System.out.print("16:");break;
case 'H':System.out.print("17:");break;
case 'I':System.out.print("18:");break;
case 'J':System.out.print("19:");break;
case 'K':System.out.print("20:");break;
case 'L':System.out.print("21:");break;
case 'M':System.out.print("22:");break;
case 'N':System.out.print("23:");break;
}
/*全部找到之后,结束循环,这里要结束一下,因为循环结束的条件是i<line1.length
由于不知道line1长还是line2长,需要break一下,否则超出数组长度会报错*/
break;
}
}
}
//寻找三四行第一对相同的英文字母
for(int i=0;i<line3.length;i++){
//满足的条件
if(line3[i]==line4[i]&&((line3[i]>='A'&&line3[i]<='Z')||(line3[i]>='a'&&line3[i]<='z'))){
if(i<10){
System.out.print("0"+i);
}else{
System.out.print(i);
}
//这里也是找到了就退出循环
break;
}
}
}
}