赞
踩
有一种技巧可以对数据进行加密,它使用一个单词作为它的密匙。下面是它的工作原理:首先,选择一个单词作为密匙,如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。
请实现下述接口,通过指定的密匙和明文得到密文。
数据范围:1≤100 1≤n≤100 ,保证输入的字符串中仅包含小写字母
先输入key和要加密的字符串
返回加密后的字符串
-
- nihao
ni
le
1,2,3,4,1,2,3,1,2,3,4,5,6
- # coding:utf-8
-
- import sys
-
- try:
- while True:
- line = sys.stdin.readline().strip()
- if line == '':
- break
- lines = line.split()
- # print(lines)
- s2 = list(lines[0])
- line2 = sys.stdin.readline().strip()
- if line2 == '':
- break
- lines2 = line2.split()
- s1 = list(lines2[0])
- res = []
- lts = ['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']
- lt = ['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']
- # 对秘钥字符串进行去重,并在自然字母表中剔除掉已有的秘钥字符串
- s3 = []
- for i in range(len(s2)):
- if s2[i] in s3:
- continue
- else:
- s3.append(s2[i])
- lt.remove(s2[i])
- # 将秘钥字符串和剔除秘钥的字母表连在一起,行成新的密码表
- s4 = s3 + lt
- # 对需要加密的字符串按照新的密码表进行加密
- for i in range(len(s1)):
- index = lts.index(s1[i])
- res.append(s4[index])
- print(''.join(res))
-
- except:
- pass
'运行
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。