题目描述
大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm”。大侦探很快就明白了,字条上奇怪的乱码实际上就是约会的时间“星期四 14:04”,因为前面两字符串中第1对相同的大写英文字母(大小写有区分)是以及大写字母A到N表示);后面两字符串第1对相同的英文字母's'出现在第4个位置(从0开始计数)上,代表第4分钟。现给定两对字符串,第4个字母'D',代表星期四;第2对相同的字符是'E',那是第5个英文字母,代表一天里的第14个钟头(于是一天的0点到23点由数字0到9、请帮助福尔摩斯解码得到约会的时间。
输入描述:
输入在4行中分别给出4个非空、不包含空格、且长度不超过60的字符串。
输出描述:
在一行中输出约会的时间,格式为“DAY HH:MM”,其中“DAY”是某星期的3字符缩写,即MON表示星期一,TUE表示星期二,WED表示星期三,THU表示星期四,FRI表示星期五,SAT表示星期六,SUN表示星期日。题目输入保证每个测试存在唯一解。
输入例子:
3485djDkxh4hhGE
2984akDfkkkkggEdsb
s&hgsfdk
d&Hyscvnm
输出例子:
THU 14:04
import java.util.Scanner;
public class Holmes {
public static void main(String[] args) {
//存放星期内容,用于输出
String[] days = {"MON","TUE","WED","THU","FRI","SAT","SUN"};
//采用StringBuffer格式,用于存放第一二个字符串中对应的字符
StringBuffer buffer = new StringBuffer();
//用于存放四个字符串
String[] strings = new String[4];
Scanner in = new Scanner(System.in);
for (int i = 0; i < strings.length; i++) {
String str = in.next();
strings[i] = str;
}
/*
* 取一二字符串的较短距离用于循环
* 判断对应字符是否相同,且为数字或者大写字母。满足条件则附加到StringBuffer字符串中
*/
int minLength = (strings[0].length() > strings[1].length() ? strings[1].length():strings[0].length());
for (int i = 0; i < minLength; i++) {
if ( (strings[0].charAt(i) == strings[1].charAt(i)) &&
( (strings[0].charAt(i) >= 'A') && (strings[0].charAt(i) <= 'Z')
|| Character.isDigit(strings[0].charAt(i))
)
) {
buffer.append(strings[0].charAt(i)).append(" ");
}
}
/*
* 因一二字符串相同字符数量难以确定,所以直接创建minute变量用于存放三四字符中第一对相同字符的下标
* 遍历字符串,判断条件,得到第一对相同字母的下标,立即中止循环,将下标赋值给minute
*/
int minute = 0;
int minLength2 = (strings[2].length() > strings[3].length() ? strings[3].length():strings[2].length());
for (int i = 0; i < minLength2; i++) {
if ((strings[2].charAt(i) == strings[3].charAt(i))&&
( (strings[2].charAt(i)>='A'&&strings[2].charAt(i)<='Z')
|| (strings[2].charAt(i)>='a'&&strings[2].charAt(i)<='z') )
) {
minute = i;
break;
}
}
/*
* 对StringBuffer内容进行处理
* 判断StringBuffer第一个字符是否为字母,不是则删除并遍历下一个元素
* 这里少处理一步,确保首字母处于A~G之间,但给出示例肯定不会超过G
*/
while(true){
if(!isCharacter(buffer.charAt(0))){
buffer.deleteCharAt(0);
if(isCharacter(buffer.charAt(0))){
break;
}
}
}
//将StringBuffer字符串内容分割成字符串数组,字符串数组中存放字母或者数字
String[] str = buffer.toString().split(" ");
// for (String string : str) {
// System.out.println(string);
// }
//A表示周一...G表示周日,用dayCursor表示输出星期内容的下标
int dayCursor = str[0].compareTo("A");
//0-9,A-N对应0-23点
int hour;
if (isNumeric(str[1])) {
hour = Integer.parseInt(str[1]);
}else{
hour = str[1].compareTo("A")+10;
}
//打印输出星期内容
System.out.print(days[dayCursor]+" ");
//格式化输出时分
System.out.printf("%02d:%02d",hour,minute);
}
//判断字符串是否为数字
public static boolean isNumeric(String str)
{
for (int i = 0; i < str.length(); i++)
{
if (!Character.isDigit(str.charAt(i)))
{
return false;
}
}
return true;
}
//判断字符是否为英文字母
public static boolean isCharacter(char c){
int i =(int) c;
if((i >= 65 && i <= 90)
|| (i >= 97 && i <= 122)){
return true;
}else{
return false;
}
}
}