1029 旧键盘
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及实际被输入的文字,请你列出肯定坏掉的那些键。
输入格式:
输入在 2 行中分别给出应该输入的文字、以及实际被输入的文字。每段文字是不超过 80 个字符的串,由字母 A-Z(包括大、小写)、数字 0-9、以及下划线 _(代表空格)组成。题目保证 2 个字符串均非空。
输出格式:
按照发现顺序,在一行中输出坏掉的键。其中英文字母只输出大写,每个坏键只输出一次。题目保证至少有 1 个坏键。
输入样例:
7_This_is_a_test
_hs_s_a_es
输出样例:
7TI
思路:
暴力破解,将第一个字符串的各个字符与第二个字符串的各个字符进行比较,如果找不到,并且判断该字符串是否在追加字符串中出现过,如果不在,将该字符转成大写字符追加到字符串中。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scan=new Scanner(System.in);
String s1=scan.next();
String s2=scan.next();
boolean b=false;
int num=0;
int j;
StringBuffer sb=new StringBuffer();
for (int i = 0; i < s1.length(); i++) {
num=0;
for (j = 0; j < s2.length(); j++) {
if(s1.charAt(i)!=s2.charAt(j)) {
b=true;
num++;
}else {
break;
}
}
if(num==s2.length()) {
b=false;
if(s1.charAt(i)>='a'&&s1.charAt(i)<='z') {
char c=(char)(s1.charAt(i)-32);
for (int k = 0; k < sb.length(); k++) {
if(sb.toString().charAt(k)==c) {
b=true;
continue;
}
}
if(!b) {
sb.append(c);
}
}else {
b=false;
char c=s1.charAt(i);
for (int k = 0; k < sb.length(); k++) {
if(sb.toString().charAt(k)==c) {
b=true;
continue;
}
}
if(!b) {
sb.append(c);
}
}
}
}
System.out.println(sb.toString());
}
}