华为机试36-字符串加密(难)
题目描述
有一种技巧可以对数据进行加密,它使用一个单词作为它的密匙。下面是它的工作原理:首先,选择一个单词作为密匙,如TRAILBLAZERS。如果单词中包含有重复的字母,只保留第1个,其余几个丢弃。现在,修改过的那个单词属于字母表的下面,如下所示:
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
T R A I L B Z E S C D F G H J K M N O P Q U V W X Y
上面其他用字母表中剩余的字母填充完整。在对信息进行加密时,信息中的每个字母被固定于顶上那行,并用下面那行的对应字母一一取代原文的字母(字母字符的大小写状态应该保留)。因此,使用这个密匙,Attack AT DAWN(黎明时攻击)就会被加密为Tpptad TP ITVH。
本题有多组输入数据,请使用while(cin>>)读取
输入描述:
先输入key和要加密的字符串
输出描述:
返回加密后的字符串
示例1
输入
nihao
ni
输出
le
参考:
while True: try: #key,string分别代表输入的key的加要密的字符串 #chars是密钥对应的字母表,res是要返回的结果。 key, string, chars, res = input(), input(), [], "" #经过下面的循环,chars前面几个是密匙的字母 for i in key: if i not in chars: chars.append(i) #如果输入的key中有小写字母,转为大写字母。 chars = list(map(lambda c: c.upper(), chars)) #剩下的字母,填充到chars里面。 for i in range(65, 91): if chr(i) not in chars: chars.append(chr(i)) # 将输入加密。 for i in string: if i.isupper(): res += chars[ord(i) - 65] elif i.islower(): res += chars[ord(i) - 97].lower() else: res += i print(res) except: break
执行结果: 答案正确:恭喜!您提交的程序通过了所有的测试用例 用例通过率: 100.00% 运行时间:17ms 占用内存: 3416KB

浙公网安备 33010602011771号