PTA 1029 旧键盘

题目链接
思路:定义三个字符数组,一个用来表示输入文本(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;
} 

猜你喜欢

转载自blog.csdn.net/thwwu/article/details/81186529