PAT——1033 旧键盘打字

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

输入格式:

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

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

输出格式:

在一行中输出能够被打出的结果文字。如果没有一个字符能被打出,则输出空行。

样例:">输入样例:

7+IE.
7_This_is_a_test.

输出样例:

_hs_s_a_tst

代码长度限制

16 KB

时间限制

200 ms

内存限制

64 MB

解题思路:题目本身倒是不难,遍历给定的字符串,然后逐个字符判断它是否是坏键,如果是不输出,否则输出即可。

就是有二个测试点容易出错:

测试点2:题目保证第二个字符串不为空,但没说第一个字符串不为空,所以第一个字符串可能是为空的即没有坏键,所以在输入第一个字符串的时候要使用getline()

测试点4:题目中说 ,.-+(代表上档键)意思是+号代表上档键,出现+则所有大写字母都无法输出,可能很多人会把,- +这三个字符当作上档键从而报错。

 

#include<iostream>
using namespace std;
int main()
{
	string a,b;
	char str[100000];        //str数组保存不是坏键的字符
	getline(cin,a);         //第一行字符串必须getline接收
	getline(cin,b);      
	int flag = 0;           //flag标志是否是坏键
	int k = 0;
	int flag1 = 0;          //flag1标志是否出现了+号
	for(int i=0;i<(int)b.length();i++)
	{
        flag = 0;
	    for(int j=0;j<(int)a.length();j++)
	    {
	    	if(a[j]==b[i]||a[j]==b[i]+32||a[j]==b[i]-32)   //判断是否是坏键
	    	   flag = 1;
	    	if(a[j]=='+')                                 //判断是否出现了+号
	    	   flag1 = 1;
		} 
		if(flag==0)
		   str[k++] = b[i];
	}
	for(int i=0;i<k;i++)
	{
        if(flag1==0)
           cout<<str[i];
        else
        {
        	if(str[i]<='Z'&&str[i]>='A')        //出现了+号坏键,则所有大写字母都不能输出
        	    continue;
        	else
        	    cout<<str[i];
		}
	}
    cout<<endl;
	return 0;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值