PAT乙级(算法初步) PAT.B1029——旧键盘

简介: PAT乙级(算法初步) PAT.B1029——旧键盘

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

输入格式:

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

输出格式:

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

输入样例:

7_This_is_a_test
_hs_s_a_es

输出样例:

7TI

代码:

(1)

#include<stdio.h>
#include<string.h>
int main() {
    char str1[100] = { 0 }, str2[100] = { 0 }, str3[100] = { 0 };//str1存放应该输入,str2存放实际输入,str3存放坏键,即结果
    gets(str1);
    gets(str2);
    int len1 = strlen(str1);
    int len2 = strlen(str2);
    int count1 = 0, count2 = 0, len3 = 0;//count1用来判断该字符是否在实际输入中,count2用来判断该字符是否在坏键中,len3存放坏键字符串长度
    for (int i = 0; i < len1; i++) {//遍历应该输入字符串
        count1 = 0, count2 = 0;//每次循环count1和count2需要归零
        for (int j = 0; j < len2; j++) {//遍历实际输入字符串
            if (str1[i] == str2[j]) {//如果当前扫描的应该输入字符串的字符和实际输入字符串的字符相同
                count1 = 1;//count1改为1,表示找到相同字符
                break;//跳出当前循环
            }
        }
        if (count1 == 0) {//如果结束上层循环后,count1为0,则说明没有在实际输入字符串中没有找到该字符
            if (str1[i] >= 'a' && str1[i] <= 'z') {//如果当前扫描的应该输入字符串的字符为小写字母
                str1[i] -= 32;//则减去32,将其转换为大写字符
            }
            for (int k = 0; k < len3; k++) {//遍历坏键字符串
                if (str1[i] == str3[k]) {//如果坏键字符串中已经有当前扫描到的字符
                    count2 = 1;//则将count2改为1,表示已经存储该字符
                    break;//跳出当前循环
                }
            }
            if (count2 == 0) {//如果count2为0,即坏键字符串中没有该字符
                str3[len3] = str1[i];//则坏键字符串的len3处加入该字符
                len3++;//len3+1,用来存放下个字符
            }
        }
    }
    printf("%s", str3);
}

(2)

#include<stdio.h>
#include<string.h>
#include<stdbool.h>
int main() {
  char str1[100] = { 0 }, str2[100] = { 0 };
  bool HashTable[128] = { false };//HashTable数组来标记字符是否已被输出
  gets(str1);
  gets(str2);
  int len1 = strlen(str1);
  int len2 = strlen(str2);
  for (int i = 0; i < len1; i++) {//枚举第一个字符串中的每个字符
    int j;
    char c1, c2;
    for (j = 0; j < len2; j++) {//枚举第二个字符串中的每个字符
      c1 = str1[i];
      c2 = str2[j];
      if (c1 >= 'a' && c1 <= 'z') c1 -= 32;//如果为小写字母,则转换为大写
      if (c2 >= 'a' && c2 <= 'z') c2 -= 32;//如果为小写字母,则转换为大写
      if (c1 == c2) break; //如果c1在第二个字符串中出现,则跳出
    }
    if (j == len2 && HashTable[c1] == false) {
      printf("%c", c1);//在第二个字符串中未出现c1,且c1未被输出过
      HashTable[c1] = true;
    }
  }
  return 0;
}
相关文章
|
算法 搜索推荐
PAT乙级 (其他高效技巧和算法) 1040、1045
PAT乙级 (其他高效技巧和算法) 1040、1045
82 0
|
存储 算法 C++
【算法笔记题解】PAT A.1095 Cars on Campus (30 分)
【算法笔记题解】PAT A.1095 Cars on Campus (30 分)
【算法笔记题解】PAT A.1095 Cars on Campus (30 分)
【算法笔记题解】PAT A1083.List Grades(25)
【算法笔记题解】PAT A1083.List Grades(25)
【算法笔记题解】PAT A1083.List Grades(25)
|
算法 测试技术
【算法笔记题解】PAT A1075 PAT Judge
【算法笔记题解】PAT A1075 PAT Judge
【算法笔记题解】PAT A1075 PAT Judge
|
存储 算法
再学一道算法题:PAT排名汇总 (排序+存储)
再学一道算法题:PAT排名汇总 (排序+存储)
|
算法 数据挖掘 Python
用python统计数据分析PAT甲乙级算法的考试和训练策略,附加横向设计图
python是做统计数据的好工具,在学习程序设计时,我们发现算法是一个难点,我们从’简单模拟’, ‘查找元素’, ‘图形输出’, ‘进制转换’, ‘字符串处理’,‘排序’,‘散列’,‘贪心’,‘二分’,‘two pointers’,‘其他’,‘数学’,‘链表’,几个角度分析算法的考试和训练策略,下一篇文章,分析数据结构的算法的考试和训练策略,如果你正在准备PAT甲乙级算法的考试和训练,会大有帮助,祝早日金榜题名。
用python统计数据分析PAT甲乙级算法的考试和训练策略,附加横向设计图
|
算法 存储
算法学习之路|PAT Ranking
Programming Ability Test (PAT) is organized by the College of Computer Science and Technology of Zhejiang University.
1174 0
|
算法
算法学习之路|有几个PAT
字符串APPAPT中包含了两个单词“PAT”,其中第一个PAT是第2位(P),第4位(A),第6位(T);第二个PAT是第3位(P),第4位(A),第6位(T)。
1399 0
|
29天前
|
算法 安全 数据安全/隐私保护
基于game-based算法的动态频谱访问matlab仿真
本算法展示了在认知无线电网络中,通过游戏理论优化动态频谱访问,提高频谱利用率和物理层安全性。程序运行效果包括负载因子、传输功率、信噪比对用户效用和保密率的影响分析。软件版本:Matlab 2022a。完整代码包含详细中文注释和操作视频。
|
6天前
|
算法 数据安全/隐私保护 索引
OFDM系统PAPR算法的MATLAB仿真,对比SLM,PTS以及CAF,对比不同傅里叶变换长度
本项目展示了在MATLAB 2022a环境下,通过选择映射(SLM)与相位截断星座图(PTS)技术有效降低OFDM系统中PAPR的算法实现。包括无水印的算法运行效果预览、核心程序及详尽的中文注释,附带操作步骤视频,适合研究与教学使用。
下一篇
无影云桌面