1029 旧键盘 (20 分)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SEVENY_/article/details/83045819

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

输入格式:

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

输出格式:

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

输入样例:

7_This_is_a_test
_hs_s_a_es

输出样例:

7TI

代码1:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int main()
{
	char s1[100],s2[100];
	scanf("%s%s",s1,s2);
	int inds2=0;
	for(int i=0;i<strlen(s1);i++)
	{
		if(s1[i]==s2[inds2])
		{
			s1[i]=' ';    //如果s1的字符s2中存在,那么将s1中此字符设为空
			inds2++;
		}
		if(s1[i]>='a'&&s1[i]<='z') //如果s1字符为小写字母,转换为大写字母
    		s1[i]+='A'-'a'; 
	} 
	for(int i=0;i<strlen(s1);i++)
	{
		for(int j=i+1;j<strlen(s1);j++)
		{
			if(s1[i]==s1[j])   //将重复的字符设置为只保留一个
			  s1[j]=' ';
		}
	}
	for(int i=0;i<strlen(s1);i++)
	{
		if(s1[i]!=' ')
		 printf("%c",s1[i]);
	}
	return 0;
 } 

代码2: 

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
 int main()
 {
 	string s1,s2;
 	cin>>s1>>s2;
 	bool vis[277]={false};   
 	for(int i=0;s2[i]!='\0';i++)
 	{
 		s2[i]=toupper(s2[i]);
 		vis[s2[i]]=true;
	}
	for(int i=0;s1[i]!='\0';i++)
	{
		s1[i]=toupper(s1[i]);
		if(vis[s1[i]]==false)
		  printf("%c",s1[i]);
		vis[s1[i]]=true;
	}
	return 0;
 }

猜你喜欢

转载自blog.csdn.net/SEVENY_/article/details/83045819
今日推荐