链接:https://www.nowcoder.com/questionTerminal/f88dafac00c8431fa363cd85a37c2d5e?f=discussion
来源:牛客网
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及实际被输入的文字,请你列出
肯定坏掉的那些键。
输入描述:
输入在2行中分别给出应该输入的文字、以及实际被输入的文字。每段文字是不超过80个字符的串,由字母A-Z(包括大、小写)、数字0-9、
以及下划线“_”(代表空格)组成。题目保证2个字符串均非空。
输出描述:
按照发现顺序,在一行中输出坏掉的键。其中英文字母只输出大写,每个坏键只输出一次。题目保证至少有1个坏键。
示例1
输入
7_This_is_a_test
_hs_s_a_es
输出
7TI
import java.util.*;
public class Main{
//strExce:7_This_is_a_test
//strActual:_hs_s_a_es
public static void func(String strExce, String strActual){
//1.先把坏键字符串放进set
Set<Character> setA = new HashSet<>();
for(int i = 0; i < strActual.length(); i++){
setA.add(strActual.charAt(i));
setA.add(Character.toUpperCase(strActual.charAt(i)));
}
//2.把正常字符串放进set 要顺序所以TreeSet
Set<Character> setE = new TreeSet<>();
for(int i = 0; i < strExce.length(); i++){
if(!setA.contains(strExce.charAt(i))){
if(!setE.contains(strExce.charAt(i))){
System.out.print(Character.toUpperCase(strExce.charAt(i)));
setE.add(strExce.charAt(i));
setE.add(Character.toUpperCase(strExce.charAt(i)));
}
}
}
}
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
String str1 = sc.next();
String str2 = sc.next();
func(str1, str2);
}
}