1033 旧键盘打字
分数 20
作者 CHEN, Yue
单位 浙江大学
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及坏掉的那些键,打出的结果文字会是怎样?
输入格式:
输入在 2 行中分别给出坏掉的那些键、以及应该输入的文字。其中对应英文字母的坏键以大写给出;每段文字是不超过 10
5
个字符的串。可用的字符包括字母 [a-z, A-Z]、数字 0-9、以及下划线 _(代表空格)、,、.、-、+(代表上档键)。题目保证第 2 行输入的文字串非空。
注意:如果上档键坏掉了,那么大写的英文字母无法被打出。
输出格式:
在一行中输出能够被打出的结果文字。如果没有一个字符能被打出,则输出空行。
输入样例:
7+IE.
7_This_is_a_test.
输出样例:
_hs_s_a_tst
代码长度限制
16
#include<stdio.h>
#include<string.h>
int main()
{
char a[10001],b[10001],d[10001];
gets(b);
gets(a);
int i=0,f=1,t=1,k=0,j=0;
int lenb,lena;
lena=strlen(a);
lenb=strlen(b);
for(j=0;j<lenb;j++)
{ if(b[j]=='+')
{ f=0;break;} }
for(i=0;i<lena;i++)
{
t=1;
for(j=0;j<lenb;j++)
{
if(a[i]==b[j] || b[j]+32==a[i] || b[j]-32==a[i])
{t=0;break;}
}
if(t!=0 && f==1)
d[k++]=a[i];
if(t!=0 && f==0 && a[i]>='Z' && a[i]<='A')
d[k++]=a[i];
}
d[k]='\0';
for(i=0;i<k;i++)
printf("%c",d[i]);
return 0;
}