1014 福尔摩斯的约会 (20分)(JAVA解题)

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
分钟是 相同位置相同字母的位置
解题时要注意星期和小时的约束条件

我的代码有点冗杂,这里放入另一篇文章

import java.util.Scanner;

public class Main {

	static Scanner cin = new Scanner(System.in);
	
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		
		String aString = cin.nextLine();
		String bString = cin.nextLine();
		String cString = cin.nextLine();
		String dString = cin.nextLine();
		
		//前两个字符串只判断大写的
		char[] aa = aString.toCharArray();
		char[] bb = bString.toCharArray();
		//后两个字符串判断位置
		char[] cc = cString.toCharArray();
		char[] dd = dString.toCharArray();
		
		//存储结果
		char aResult = 0;
		char bResult = 0;
		
		int position = 0;
	//判断是星期还是小时
		int sign = 1;
		//yiyi对应
		for (int i = 0; i<aa.length && i < bb.length; i++) {
			if (aa[i] == bb[i]) {
				//找星期
				if (sign == 1 && aa[i]>='A'&&aa[i]<='G') {
					aResult = aa[i];
					sign++;
					continue;
				}else if (sign == 2) {
					if (aa[i]>='A'&&aa[i]<='N' || aa[i]>='0'&&aa[i]<='9') {
						bResult = bb[i];
						sign++;
						break;
					}
				}
			}
		}
		
		boolean temp = false;
		for (int i = 0; i < cc.length && i<dd.length; i++) {
			//必须英文字母相同
			if (cc[i]>='a'&&cc[i]<='z' || cc[i]>='A'&&cc[i]<='Z') {
				if (cc[i] == dd[i] ) {
					position = i;
					break;
				}
			}
		}
		
		switch (aResult) {
		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;
		default:
			break;
		}
		System.out.print(" ");
		
		System.out.print(PrintHour(bResult));
		
		System.out.print(":");
		if (position>=0&&position<=9) {
			System.out.print("0"+position);
		}else {
			System.out.print(position);
		}
	}

	private static String PrintHour(char bResult) {
		String result = "";
		
		switch (bResult) {
		case '0':
			result = "00";
			break;
		case '1':
			result = "01";
			break;
		case '2':
			result = "02";
			break;
		case '3':
			result = "03";
			break;
		case '4':
			result = "04";
			break;
		case '5':
			result = "05";
			break;
		case '6':
			result = "06";
			break;
		case '7':
			result = "07";
			break;
		case '8':
			result = "08";
			break;
		case '9':
			result = "09";
			break;
		case 'A':
			result = "10";
			break;
		case 'B':
			result = "11";
			break;
		case 'C':
			result = "12";
			break;
		case 'D':
			result = "13";
			break;
		case 'E':
			result = "14";
			break;
		case 'F':
			result = "15";
			break;
		case 'G':
			result = "16";
			break;
		case 'H':
			result = "17";
			break;
		case 'I':
			result = "18";
			break;
		case 'J':
			result = "19";
			break;
		case 'K':
			result = "20";
			break;
		case 'L':
			result = "21";
			break;
		case 'M':
			result = "22";
			break;
		case 'N':
			result = "23";
			break;
		default:
			break;
		}
		return result;
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值