您的位置:首页 > 其它

PAT 1033. 旧键盘打字(20)

2017-11-30 11:26 246 查看
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及坏掉的那些键,打出的结果文字会是怎样?

输入格式:

输入在2行中分别给出坏掉的那些键、以及应该输入的文字。其中对应英文字母的坏键以大写给出;每段文字是不超过105个字符的串。可用的字符包括字母[a-z, A-Z]、数字0-9、以及下划线“_”(代表空格)、“,”、“.”、“-”、“+”(代表上档键)。题目保证第2行输入的文字串非空。

注意:如果上档键坏掉了,那么大写的英文字母无法被打出。

输出格式:

在一行中输出能够被打出的结果文字。如果没有一个字符能被打出,则输出空行。
输入样例:
7+IE.
7_This_is_a_test.

输出样例:

_hs_s_a_tst

代码如下:

题目大意为 输入两串字符串,第一串为坏掉的键 其中+为上档键 这个键坏掉了之后 所有的大写字母将不可打印 —为空格,输出第二串字符串中和第一个字符串不相同即为结果

代码如下:

#include<iostream>

#include<string>

using namespace std;

int main()

{
string s1,s2;     
int flag=0;
getline(cin,s1);
getline(cin,s2);
for(long i=0;i<s1.length();i++){
if(s1[i]=='+'){         //判断上档键是否坏掉
flag = 1;
break;
}

if(flag==1)            //如果坏了,就把s2中所有的大写字母设置为不可输出
for(int i=0;i<s2.length();i++)
if(s2[i]>='A'&&s2[i]<='Z')
s2[i]='*';
for(int i=0;i<s2.length();i++){   //判断s1和s2中相同的字符
for(int j=0;j<s1.length();j++){
if(s1[j]==s2[i]){
s2[i]='*';
continue;
}
if( (s1[j]>='A'&&s1[j]<='Z') && s1[j] == s2[i] - 32){      //s1中全部为大写字母
s2[i] = '*';
continue;
}
flag=2;
}
if(s2[i]!='*') putchar(s2[i]);        //输出符合的字符即可
}
if(flag==2)
printf("\n");
return 0;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: