合规国际互联网加速 OSASE为企业客户提供高速稳定SD-WAN国际加速解决方案。 广告
[TOC] ## 原题: 旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及实际被输入的文字,请你列出肯定坏掉的那些键。 输入格式: 输入在2行中分别给出应该输入的文字、以及实际被输入的文字。每段文字是不超过80个字符的串,由字母A-Z(包括大、小写)、数字0-9、以及下划线“_”(代表空格)组成。题目保证2个字符串均非空。 输出格式: 按照发现顺序,在一行中输出坏掉的键。其中英文字母只输出大写,每个坏键只输出一次。题目保证至少有1个坏键。 输入样例: 7_This_is_a_test _hs_s_a_es 输出样例: 7TI ##分析(伪代码和知识点): ![](https://box.kancloud.cn/2016-05-06_572c24a5ad1c2.png)! ![](https://box.kancloud.cn/2016-05-06_572c24a5c4df3.png)! ## 代码如下: ~~~ #include <stdio.h> #include <string.h> #include <ctype.h> int main(void) { char a[82],b[82],c[82],d; int n=0,i,j=0,k=0,flag; scanf("%s %s",a,b); for(i=0;i<strlen(a);i++) { if((a[i]==b[j])&&(j<strlen(b))) j++; else { flag = 0; if(islower(a[i])) a[i]=a[i]-32; for(k=0;k<n;k++) if(a[i]==c[k]) flag=1; if(flag==0) c[n++]=a[i]; } } for(i=0;i<n;i++) printf("%c",c[i]); } ~~~ ![](https://box.kancloud.cn/2016-05-06_572c24a5dcf39.png)