PAT(B) 1014 福爾摩斯的約會(Java)

題目連接:1014 福爾摩斯的約會
注意
  • 三個字眼:「第1對」,「第2對」,「第1對」,所以若是你用了循環,別忘了break,由於後面也可能有相同的字母
  • 星期幾,第1對相同的A-GA表明"MON"D表明THU
  • 小時(鐘頭),0-9A-N
  • 題目保證有惟一解,所以不須要使用Math.min(int a, int b)獲取較短長度,來避免越界
  • 分鐘,A-Za-z
  • 小時和分鐘任什麼時候候都是佔2
  • 長度不超過60直接忽略,沒用。
輸入樣例:
j454HkCTOtFN5uh
J65tHkCtOtFN4
&.\6wowpHnv
&.\6WOWpH
輸出樣例:
WED 15:07

上面的樣例能測試注意中涉及到的全部細節。java

代碼
/** * Score: 20 * Run Time: 120ms * @author wowpH * @version 1.6 */

import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		String[] s = new String[4];
		String[] week = { "MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN" };

		Scanner sc = new Scanner(System.in);
		for (int i = 0; i < 4; i++) {
			s[i] = sc.next();// 輸入
		}
		sc.close();

		// 星期幾
		int i;
		char ch;
		int len = s[0].length();
		for (i = 0; i < len; i++) {
			ch = s[0].charAt(i);
			if (ch == s[1].charAt(i)) {
				if (ch >= 'A' && ch <= 'G') {// A~G
					System.out.print(week[ch - 'A'] + " ");// 星期幾
					break;
				}
			}
		}

		// 小時
		for (i = i + 1; i < len; i++) {
			ch = s[0].charAt(i);
			if (ch == s[1].charAt(i)) {
				if (Character.isDigit(ch)) {// 0~9
					System.out.printf("%02d:", ch - '0');
					break;
				} else if (ch >= 'A' && ch <= 'N') {// A~N
					System.out.printf("%02d:", ch - 'A' + 10);
					break;
				}
			}
		}

		// 分鐘
		len = s[2].length();
		for (i = 0; i < len; i++) {
			ch = s[2].charAt(i);
			if (ch == s[3].charAt(i)) {
				// A~Z或a~z
				if (ch >= 'A' && ch <= 'Z' || ch >= 'a' && ch <= 'z') {
					System.out.printf("%02d\n", i);
					break;
				}
			}
		}
	}
}
相關文章
相關標籤/搜索