本文主要是介绍PAT 乙级 1029 旧键盘,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1029 旧键盘
分数 20
作者 CHEN, Yue
单位 浙江大学
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及实际被输入的文字,请你列出肯定坏掉的那些键。
输入格式:
输入在 2 行中分别给出应该输入的文字、以及实际被输入的文字。每段文字是不超过 80 个字符的串,由字母 A-Z(包括大、小写)、数字 0-9、以及下划线 _(代表空格)组成。题目保证 2 个字符串均非空。
输出格式:
按照发现顺序,在一行中输出坏掉的键。其中英文字母只输出大写,每个坏键只输出一次。题目保证至少有 1 个坏键。
输入样例:
7_This_is_a_test
_hs_s_a_es
输出样例:
7TI
解题思路 python版:我开始想用python版本的集合,后来一看不可以用,原因就是集合是无序的,还是用了列表,我们这里要注意列表有没有,没有再加,保证列表里面只有一个相关元素,删除的时候同理,最后剩下的即保证了顺序也保证了唯一性,还有别忘了字母大写。python代码如下:
s1=input().upper()
s2=input().upper()
s=[]
for i in range(0,len(s1)):if s1[i] not in s:s.append(s1[i])
for i in range(0,len(s2)):if s2[i]in s:s.remove(s2[i])
print(''.join(s))
c语言版本:解题思路:我先利用hash算出每个字母出现的次数。然后再根据后面的字符去删次数,次数不为0的就是我们要的,切记我们输出之后要把数量改为0,不然就重复输出了
#include<stdio.h>
int upper(int c)
{if(c>='a'&&c<='z'){c-=32;}return c;
}
int main()
{int count[128]={0},i;char a[82],b[82];scanf("%s%s",a,b);for(i=0;a[i]!='\0';i++){count[upper(a[i])]++;}for(i=0;b[i]!='\0';i++){count[upper(b[i])]--;}for(i=0;a[i]!='\0';i++){if(count[upper(a[i])]!=0){count[upper(a[i])]=0;printf("%c",upper(a[i]));}}printf("\n");return 0;
}
这篇关于PAT 乙级 1029 旧键盘的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!