原题地址:https://www.nowcoder.com/pat/6/problem/4040
防止广告嫌疑,原题为:
题目描述
大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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
花了2个小时多小时,终于调试出,代码如下:
package ceshi; import java.util.Arrays;import java.util.List;import java.util.Scanner;import java.util.Vector; /** * Created by mrma on 17-4-10. */public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int i = 0; String yu[] = new String[4]; while (i < 4){ yu[i] = sc.nextLine(); i++; } char a[][] = new char[yu.length][]; int tongyi[] = new int[3]; for (i = 0;i<yu.length;i++){ a[i] = yu[i].toCharArray(); } int j = 0; for(i = 0;i<a[0].length;i++){ if(a[0][i] == a[1][i]){ if(a[0][i] >= 65 && a[0][i] <= 90){ tongyi[j] = a[0][i] - 65 + 1; if(j == 1) tongyi[j] += 9; j++; } if(tongyi[0] != 0 && a[0][i] >= ‘0‘ && a[0][i]<=‘9‘){ tongyi[1] = Integer.valueOf(String.valueOf(a[0][i])); j++; } } if(j == 2) break; } for(i = 0;i<a[2].length;i++){ if(a[2][i] == a[3][i] && a[2][i]>= 97 && a[2][i]<=122 ){ tongyi[2] = i; break; } } String jg=""; switch (tongyi[0]){ case 1: jg = "MON "; break; case 2: jg = "TUE "; break; case 3: jg = "WED "; break; case 4: jg = "THU "; break; case 5: jg = "FRI "; break; case 6: jg = "SAT "; break; case 7: jg = "SUN "; break; } System.out.print(jg); System.out.printf("%02d",tongyi[1]); System.out.printf(":%02d",tongyi[2]); sc.close(); }}
一点一点进步了。却发现有好多现成的类没有用的,为了能简洁代码,尝试用了多次数组,也发现char类型为数字时,要先转字符串再转数字。
如果有更好的建议或想法,希望您能提出,谢谢。
时间: 2024-11-03 21:07:36