1029 旧键盘

一.问题:

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

输入格式:

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

输出格式:

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

输入样例:

7_This_is_a_test
_hs_s_a_es

输出样例:

7TI

二.思路:

        先两层循环找出没有输出的字符,单独存放在一个字符数组str3里,然后自定义一个函数将str3里面的所有英文字符确保全变为大写,再排除重复字符(变为'\0');这样就好输出了

三.代码实现:

#include
#include
//先将英文字符全部转换为大写,再去除重复字符,顺序不能乱,不然有问题
void func(char *str,int len)
{
    //将英文字符全部转换为大写
    for(int i =0;i< len;i++)
    {
        if(str[i] != '\0')
        {
            if(str[i] >= 'a'&&str[i] <= 'z')
            {
                str[i] = toupper(str[i]);
            }
        }
    }
    //去除重复字符将其转换为'\0'
    for(int i =0;i< len;i++)
    {
        for(int j =i+1;j< len;j++)
        {
            if(str[i] == str[j])
            {
                str[j] = '\0';
            }
        }
    }
}
int main()
{
    //输入数据
    char str1[81];//应该输入的文字字符串
    char str2[81];//实际被输入的文字字符串
    char str3[81];//坏掉键位的文字字符串
    scanf("%s",str1);
    scanf("%s",str2);

    //挑出没有输出的字符,即坏掉的键位符,存储到str3
    int t=0;
    for(int i =0;str1[i] != '\0';i++)
    {
        int flag = 0;
        for(int j =0;str2[j] != '\0';j++)
        {
            if(str1[i] == str2[j])
            {
                flag = 1;
            }
        }
        if(!flag)
        {
            str3[t] = str1[i];
            t++;
        }
    }

    //英文字符转大写,去除去除重复字符
    func(str3,t);
    //输出结果
    for(int i =0;i < t;i++)
    {
        if(str3[i] != '\0')
        {
            printf("%c",str3[i]);
        }
    }
    putchar('\n');
    return 0;
}

你可能感兴趣的:(PTA,(Basic,level)部分题目解析,算法)