1029 旧键盘

一.问题:

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

输入格式:

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

输出格式:

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

输入样例:

复制代码
7_This_is_a_test
_hs_s_a_es

输出样例:

复制代码
7TI

二.思路:

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

三.代码实现:

cpp 复制代码
#include<stdio.h>
#include<ctype.h>
//先将英文字符全部转换为大写,再去除重复字符,顺序不能乱,不然有问题
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;
}
相关推荐
嵌入式老牛1 小时前
液晶段码(米/日字格)识别—倾斜校正
opencv·算法·仿射变换
luj_17681 小时前
残熵算法:风险缓冲与效率优化的融合
c语言·开发语言·网络·经验分享·算法
oddsand12 小时前
pgvector 三大相似度算法
人工智能·算法·机器学习
运筹vivo@2 小时前
LeetCode 2574. 左右元素和的差值
算法·leetcode·职场和发展·每日一题
计算机安禾2 小时前
【数据库系统原理】第4篇:关系数据结构的形式化定义:域、笛卡尔积与关系模式
数据结构·数据库·算法
手写码匠2 小时前
手写 DeepSeek 推理引擎优化:从 FP16 到 INT4 的量化加速实战
人工智能·深度学习·算法·aigc
GuWenyue2 小时前
LeetCode 76 最小覆盖子串|JS 滑动窗口标准解法
前端·算法·面试
一只齐刘海的猫3 小时前
【Leetcode】移动零
算法·leetcode·职场和发展
落羽的落羽3 小时前
【项目】JsonRpc框架——开发实现1(细节功能、字段定义、抽象层、具象层)
linux·服务器·网络·c++·人工智能·算法·机器学习
handler014 小时前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集