题解 | #字符串加密# hashmap

字符串加密

http://www.nowcoder.com/practice/e4af1fe682b54459b2a211df91a91cf3

回来在吐槽一次,题目写的跟屎一样,看了好久才明白啥意思

# 时间:O(n^2+nlogn+n),空间:O(len(l)+len(key)+len(res))
def encode(key,s):  
    #考虑到加密文本有空格,所以加上空格
    l=list("abcdefghijklmnopqrstuvwxyz ") 
    res=""
    #set()去重时间O(1),sorted()排序时间O(nlogn),所以O(nlogn)
    key=sorted(set(key),key=key.index) #原序删除重复项
    # list双嵌套循环,O(n^2)
    for i in l:
        if i not in key:
            key.append(i)
    code_map=dict(zip(l,key)) #dict(zip())打包生成密码字典,O(1)
    for i in s:
        res+=code_map[i]
    print(res)

    
while True:
    try:
        key,s=input(),input()
        encode(key, s)
    except:
        break
华为机试(python3) 文章被收录于专栏

少壮不努力,老大勤刷题

全部评论

相关推荐

11-09 01:22
已编辑
东南大学 Java
高级特工穿山甲:羡慕,我秋招有家企业在茶馆组织线下面试,约我过去“喝茶详谈”😢结果我去了发现原来是人家喝茶我看着
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务