Java - PAT - 1014. 福尔摩斯的约会 (20)
来源:互联网 发布:女生基本款 知乎 编辑:程序博客网 时间:2024/05/16 04:33
大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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
import java.util.Scanner;public class Main {public static void main(String[]args){Scanner sc = new Scanner(System.in);String s1 = sc.next();String s2 = sc.next();String s3 = sc.next();String s4 = sc.next();String date[] = { "MON","TUE","WED","THU","FRI","SAT","SUN" };int time[] = {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23};System.out.print(date[Gfw(s1,s2)]+" ");System.out.printf("%02d:", time[Gsw(s1,s2)]);System.out.printf("%02d\n",getfz(s3 ,s4));}public static int Gfw(String s1,String s2){//获得第一个相同的大写字母int len1 = s1.length();for(int i=0;i<len1 ;i++){if(isUpcase(s1,i)){if(s1.charAt(i)==s2.charAt(i)){return s1.charAt(i)-65;}}}return 0;}public static int get(String s1 ,String s2){//获取第一个相同的大写字母的位置int k = Gfw(s1,s2)+65;for(int i=0 ;i<s1.length() ;i++){if(s1.charAt(i)==k){return i;}}return 0;}public static int Gsw(String s1,String s2){//获得第二个相同的字符 可以是数字或者A-N的字母int len1 = s1.length();for(int i=get(s1 ,s2)+1;i<len1 ;i++){if(isNum(s1,i)){if(s1.charAt(i)==s2.charAt(i)){return s1.charAt(i)-48;}}if(isUp2(s1,i)){if(s1.charAt(i)==s2.charAt(i)){return s1.charAt(i)-55;}}}return 0;}public static int getfz(String s1,String s2){//获取分钟int len1 = s1.length();for(int i=0 ;i<len1 ;i++){if(iszimu(s1,i)){if(s1.charAt(i)==s2.charAt(i)){return i;}}}return 0;}public static boolean isUpcase(String s,int i){//判断是否是A-G的大写字母if(s.charAt(i)>=65&&s.charAt(i)<=71){return true;}return false;}public static boolean isNum(String s,int i){if((s.charAt(i)>=48&&s.charAt(i)<=57)){//判断是否是0-9的数字return true;}return false;}public static boolean isUp2(String s,int i){if((s.charAt(i)>=65&&s.charAt(i)<=78)){//判断是否是A-N大写字母return true;}return false;}public static boolean iszimu(String s,int i){if((s.charAt(i)>=65&&s.charAt(i)<=90)||(s.charAt(i)>=97&&s.charAt(i)<=122)){//判断是否是英文字母return true;}return false;}}
0 0
- Java - PAT - 1014. 福尔摩斯的约会 (20)
- PAT 乙级 1014. 福尔摩斯的约会 (20) Java版
- PAT 1014. 福尔摩斯的约会 (20)
- PAT 1014. 福尔摩斯的约会 (20)
- PAT(B)1014. 福尔摩斯的约会 (20)
- PAT-1014. 福尔摩斯的约会 (20)
- PAT B 1014. 福尔摩斯的约会 (20)
- 1014. 福尔摩斯的约会 (20) PAT 乙级
- PAT-乙级-1014. 福尔摩斯的约会 (20)
- PAT(B) - 1014. 福尔摩斯的约会 (20)
- PAT(B) 1014. 福尔摩斯的约会 (20)
- PAT.乙级1014. 福尔摩斯的约会 (20)
- PAT-B 1014. 福尔摩斯的约会 (20)
- PAT-B 1014. 福尔摩斯的约会 (20)
- 1014. 福尔摩斯的约会 (20)-PAT乙级
- 1014. 福尔摩斯的约会 (20) PAT
- PAT乙级 1014. 福尔摩斯的约会 (20)
- PAT乙级1014. 福尔摩斯的约会 (20)
- 快速排序里的学问:随机化快排
- 从零开始学回溯算法
- DHCP源码分析-报文解析和封装
- HDOJ3565 Bi-peak Number
- C++第13周项目多态性 【项目2-动物这样叫】
- Java - PAT - 1014. 福尔摩斯的约会 (20)
- Spring事务不回滚
- C++第13周项目 多态性 【项目3-形状类族的中的纯虚函数】
- 函数的调用规则(__cdecl,__stdcall,__fastcall,__pascal)
- 动态规划 problem L
- assert的用法简介
- OpenGL像素默认像素存储格式
- Python 修改文件重命名代码
- Java千百问_06数据结构(021)_StringBuffer/StringBuilder有什么区别