1029. 旧键盘(20)
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及实际被输入的文字,请你列出肯定坏掉的那些键。
输入格式:
输入在2行中分别给出应该输入的文字、以及实际被输入的文字。每段文字是不超过80个字符的串,由字母A-Z(包括大、小写)、数字0-9、以及下划线“_”(代表空格)组成。题目保证2个字符串均非空。
输出格式:
按照发现顺序,在一行中输出坏掉的键。其中英文字母只输出大写,每个坏键只输出一次。题目保证至少有1个坏键。
输入样例:
7_This_is_a_test _hs_s_a_es输出样例:
7TI代码:
#include<iostream>
#include<string>
using namespace std;
bool isCharacter(char ch){
if ((ch >= 'a'&&ch <= 'z') || (ch >= 'A'&&ch <= 'Z'))
return true;
else return false;
}
char upper(char ch){
if (ch >= 'a'&&ch <= 'z')
return ch - 32;
else return ch;
}
int main(){
string s_i, s_o;
string re = "";
cin >> s_i >> s_o;
int i = 0, j = 0;
while (i < s_i.length()){
if (s_i[i] != s_o[j]){
if (isCharacter(s_i[i])){
int temp = re.find(upper(s_i[i]));
if (temp == -1)
re += upper(s_i[i]);
}
else{
int temp = re.find(s_i[i]);
if (temp == -1)
re += s_i[i];
}
i++;
}
else if (s_i[i] == s_o[j] && j < s_o.length()){
i++;
j++;
}
}
cout << re << endl;
system("pause");
return 0;
}
一开始的while条件把s_i和s_o的长度判断放在了一起,导致了最后一个测试点一直过不去。。。
忽略了还有一种条件:输出字符串读到最后输入串后面可能还有坏的键。。。
成功AC