Java - PAT - 1014. 福尔摩斯的约会 (20)
2016-05-22 10:55
459 查看
大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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; } }
相关文章推荐
- Java数据持久层框架 MyBatis之背景知识一
- Eclipse使用及调试
- Java内部类的应用(初级)
- 在一个工程中引用另一个工程
- Spring MVC学习笔记——JSR303介绍及最佳实践
- java二维码qrcode生成代码下载,进行加密,解密,相对于最代码xiaoxiaot的更为简便
- java中字节数组与其他各类型的转换
- Java 多线程(二) Thread类与Runnable接口的关系
- Struts2的常量配置
- 第二章、3.java高精度数字
- Json格式与java对象之间的转换
- Java compiler level does not match the version of the installed java project facet错误的解决
- java简单适配器的使用
- Spring学习之第一个AOP程序
- java中内部类访问局部变量为什么要定义局部变量为final
- Eclipse: class file editor: source not found 问题解决办法
- Class.forName()用法 c26a 详解
- Java学习从菜鸟变大鸟之二 输入输出流(IO)
- 冒泡排序——java
- Spring Mvc那点事---(10)Spring Mvc之mybatis用法