题目链接
思路:定义三个字符数组,一个用来表示输入文本(str1),一个用来表示实际的输入文本(str2),一个用来存储坏掉的键(s)。然后,逐个比较str1与str2中的字符,若两者字符相同,则继续比较;若不同,则将str1中的此位置字符存储到s中,并让str1当前所处位置往后移动,且s的长度加1。随后,对s中所有字符进行判断,首先,将小写字母转化为大写字母,其次,若重复出现,则不输出;反之,若不重复出现则输出。
AC代码:
#include<iostream>
#include<cstring>
#include<cctype>
using namespace std;
int main()
{
char str1[81],str2[81],s[81];
cin>>str1;
cin>>str2;
int len1,len2,i=0,j=0,len3=0;
len1=strlen(str1);
len2=strlen(str2);
while(i<len1)
{
if(str1[i]==str2[j])
{
i++;
j++;
}
else
{
s[len3]=str1[i];
len3++;
i++;
}
}
for(int k=0;k<len3;k++)
{
int flag=0;
if(islower(s[k]))
{
s[k]=s[k]-32;
}
for(int l=0;l<k;l++)
{
if(s[l]==s[k])
{
flag=1;
break;
}
}
if(flag==0)
cout<<s[k];
}
cout<<endl;
return 0;
}