PAT乙级1014,附详细题目解析和AC代码

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

大侦探福尔摩斯接到一张奇怪的字条:我们约会吧!3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm。大侦探很快就明白了,字条上奇怪的乱码实际上就是约会的时间星期四 14:04,因为前面两字符串中第 1 对相同的大写英文字母(大小写有区分)是第 4 个字母D,代表星期四;第 2 对相同的字符是E,那是第 5 个英文字母,代表一天里的第 14 个钟头(于是一天的 0 点到 23 点由数字 0 到 9、以及大写字母AN表示);后面两字符串第 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之间输出相应的小时,如果<9的话前面还得加个0,比如 THU 09:33

根据题目给的输入样例可以推断出,第二对相同的英文字母在第一对的后面,所以应该找到第一对相同的英文字母下标,再在此下标后面寻找第二对相同的字母

第三行和第四行相同的第一对英文字母,可以是大写也可以是小写,找完就可以退出循环了,因为只需要找第一对,防止后面还有重复的,然后重复输出。

AC代码:

import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner s=new Scanner(System.in);
        //line几就代表第几行,都转换为字符数组,
        char[] line1=s.nextLine().toCharArray();
        char[] line2=s.nextLine().toCharArray();
        char[] line3=s.nextLine().toCharArray();
        char[] line4=s.nextLine().toCharArray();
        boolean flag=true;//定义flag的作用就是当找到第一对英文字母之后,置flag=false,然后找第二对
        for(int i=0;i<line1.length;i++){
            //flag还是true的时候说明正在找第一对英文字母
            if(flag){
                //第一对满足的条件
                if(line1[i]==line2[i]&&line1[i]>='A'&&line1[i]<='G'){
                    flag=false;//找到之后置flag=false
                    switch (line1[i]){
                        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;
                    }
                }
            }else{//执行else时,flag=false,就开始寻找第二对字符
                //第二对字符满足的条件
                if(line1[i]==line2[i]&&((line1[i]>='0'&&line1[i]<='9')||(line1[i]>='A'&&line1[i]<='N'))){
                    switch (line1[i]){
                        case '0':System.out.print("00:");break;
                        case '1':System.out.print("01:");break;
                        case '2':System.out.print("02:");break;
                        case '3':System.out.print("03:");break;
                        case '4':System.out.print("04:");break;
                        case '5':System.out.print("05:");break;
                        case '6':System.out.print("06:");break;
                        case '7':System.out.print("07:");break;
                        case '8':System.out.print("08:");break;
                        case '9':System.out.print("09:");break;
                        case 'A':System.out.print("10:");break;
                        case 'B':System.out.print("11:");break;
                        case 'C':System.out.print("12:");break;
                        case 'D':System.out.print("13:");break;
                        case 'E':System.out.print("14:");break;
                        case 'F':System.out.print("15:");break;
                        case 'G':System.out.print("16:");break;
                        case 'H':System.out.print("17:");break;
                        case 'I':System.out.print("18:");break;
                        case 'J':System.out.print("19:");break;
                        case 'K':System.out.print("20:");break;
                        case 'L':System.out.print("21:");break;
                        case 'M':System.out.print("22:");break;
                        case 'N':System.out.print("23:");break;
                    }
                    /*全部找到之后,结束循环,这里要结束一下,因为循环结束的条件是i<line1.length
                    由于不知道line1长还是line2长,需要break一下,否则超出数组长度会报错*/
                    break;
                }
            }
        }
        
        //寻找三四行第一对相同的英文字母
        for(int i=0;i<line3.length;i++){
            //满足的条件
            if(line3[i]==line4[i]&&((line3[i]>='A'&&line3[i]<='Z')||(line3[i]>='a'&&line3[i]<='z'))){
                if(i<10){
                    System.out.print("0"+i);
                }else{
                    System.out.print(i);
                }
                //这里也是找到了就退出循环
                break;
            }
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值