Skip to content

1029 旧键盘

Statement

Metadata

  • 作者: CHEN, Yue
  • 单位: 浙江大学
  • 代码长度限制: 16 KB
  • 时间限制: 200 ms
  • 内存限制: 64 MB

旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及实际被输入的文字,请你列出肯定坏掉的那些键。

输入格式

输入在 2 行中分别给出应该输入的文字、以及实际被输入的文字。每段文字是不超过 80 个字符的串,由字母 A-Z(包括大、小写)、数字 0-9、以及下划线 _(代表空格)组成。题目保证 2 个字符串均非空。

输出格式

按照发现顺序,在一行中输出坏掉的键。其中英文字母只输出大写,每个坏键只输出一次。题目保证至少有 1 个坏键。

输入样例

7_This_is_a_test
_hs_s_a_es

输出样例

7TI

Solution

#include <bits/stdc++.h>
using namespace std;
int main() {
    string s1, s2;
    cin >> s1 >> s2;
    int len1 = s1.size(), len2 = s2.size(), i, j;
    map<char, int> q;
    for (i = 0; i < len1; i++) {
        if (s1[i] >= 'a' && s1[i] <= 'z')
            s1[i] -= 32;
    }
    for (i = 0; i < len2; i++)
        if (s2[i] >= 'a' && s2[i] <= 'z')
            s2[i] -= 32;
    for (i = 0, j = 0; i < len1; i++) {
        if (s1[i] != s2[j]) {
            if (q[s1[i]] != 2)
                cout << s1[i];
            q[s1[i]] = 2;
        } else
            j++;
    }
    cout << "\n";
}

Last update: May 4, 2022
Back to top