旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及坏掉的那些键,打出的结果文字会是怎样?
输入格式:
输入在 2 行中分别给出坏掉的那些键、以及应该输入的文字。其中对应英文字母的坏键以大写给出;每段文字是不超过 105 个字符的串。可用的字符包括字母 [a
-z
, A
-Z
]、数字 0
-9
、以及下划线 _
(代表空格)、,
、.
、-
、+
(代表上档键)。题目保证第 2 行输入的文字串非空。
注意:如果上档键坏掉了,那么大写的英文字母无法被打出。
输出格式:
在一行中输出能够被打出的结果文字。如果没有一个字符能被打出,则输出空行。
输入样例:
7+IE.
7_This_is_a_test.
结尾无空行
输出样例:
_hs_s_a_tst
结尾无空行
#include<stdio.h>
#include <string.h>
#pragma warning(disable:4996)
int book[1000000];
char str1[1000000];
char str2[10000000];
typedef int bool;
int main() {
gets(str1);
gets(str2);
int len1 = strlen(str1);
for (int cnt = 0; cnt < len1; cnt++) {
int temp1 = toupper(str1[cnt]);
book[temp1] = 1;
temp1 = tolower(str1[cnt]);
book[temp1] = 1;
}
int len2 = strlen(str2);
for (int cnt = 0; cnt < len2; cnt++) {
if (book[(int)str2[cnt]] != 0) str2[cnt] = 0;
}
bool judge = book[(int)'+'];
if (judge==1) {
for (int cnt = 0; cnt < len2; cnt++) {
if (str2[cnt] >= 'A' && str2[cnt] <= 'Z') str2[cnt] = 0;
}
}
int flag = 0;
for (int cnt = 0; cnt < len2; cnt++) {
if (str2[cnt] != 0) {
putchar(str2[cnt]);
flag = 1;
}
}
if (flag==0) putchar('\n');
return 0;
}
我踩过的坑:
1.我提前以为,.+-全是是上档键,然而实际上,就只有+号是上档键
2.没想到坏键可能为空再加上scanf不能吸收空的字符串所以过不了测试点3
然后有个大佬的,我粘了过来
#include <stdio.h>
#include <ctype.h>
int main() {
char A[123] = {
0
}, ch;
while ((ch = getchar()) != '\n') {
A[ch]++;
}
while ((ch = getchar()) != '\n') {
if ((isupper(ch) && A[43]) || A[toupper(ch)]) {
continue;
}
else {
putchar(ch);
}
}
return 0;
}