华为OD-字符串加密

题目描述

有一种技巧可以对数据进行加密,它使用一个单词作为它的密匙。下面是它的工作原理:首先,选择一个单词作为密匙,如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

代码实现

python 复制代码
# 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
相关推荐
子春一5 分钟前
Flutter for OpenHarmony:构建一个 Flutter 数字消消乐游戏,深入解析网格状态管理、合并算法与重力系统
算法·flutter·游戏
草履虫建模6 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq8 小时前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq9 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq9 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
好家伙VCC10 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
(❁´◡`❁)Jimmy(❁´◡`❁)10 小时前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi10 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
不能隔夜的咖喱11 小时前
牛客网刷题(2)
java·开发语言·算法
VT.馒头11 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript