题解 | #字符串加解密#

字符串加解密

https://www.nowcoder.com/practice/2aa32b378a024755a3f251e75cbf233a

描述

对输入的字符串进行加解密,并输出。

加密方法为:

当内容是英文字母时则用该英文字母的后一个字母替换,同时字母变换大小写,如字母a时则替换为B;字母Z时则替换为a;

当内容是数字时则把该数字加1,如0替换1,1替换2,9替换0;

其他字符不做变化。

解密方法为加密的逆过程。
数据范围:输入的两个字符串长度满足 1 \le n \le 1000 \1n1000  ,保证输入的字符串都是只由大小写字母或者数字组成

输入描述:

第一行输入一串要加密的密码
第二行输入一串加过密的密码

输出描述:

第一行输出加密后的字符

第二行输出解密后的字符

思路:

纯模拟,使用ord函数获得ASCII码,使用chr函数将ASCII码转换为字符。需要注意的是,加密和解密的过程中ASCII码取余来实现z和a的衔接,其中的一些细节

a=list(input())
b=list(input())
#加密
for i in range(len(a)):
    if a[i].isalpha():
        if "a"<=a[i]<="z":
            #先+1再减字母a的ASCII,此时的结果有可能超过z,通过模26再绕回来,最后得到是字母表的第几个之后再加回a
            a[i]=chr((ord(a[i])+1-ord("a"))%26+ord("a"))
            a[i]=a[i].upper()
            
        else:
            a[i]=chr((ord(a[i])+1-ord("A"))%26+ord("A"))
            a[i]=a[i].lower()
    else:
        a[i]=chr((ord(a[i])+1-ord("0"))%10+ord("0"))
#解密
for i in range(len(b)):
    if b[i].isalpha():
        if "a"<=b[i]<="z":
            #这里跟加密不一样的是,-1之后有可能结果比a小,那么就通过+26再模26的方法绕回来,
            #实际上在模运算系统里面【-1】和【+25】是同样的操作
            b[i]=chr((ord(b[i])-1-ord("a")+26)%26+ord("a"))
            b[i]=b[i].upper()
        else:
            b[i]=chr((ord(b[i])-1-ord("A")+26)%26+ord("A"))
            b[i]=b[i].lower()
    else:
        b[i]=chr((ord(b[i])-1-ord("0")+10)%10+ord("0"))
a1="".join(a)
b1="".join(b)
print(a1)
print(b1)


#华为笔试#
全部评论

相关推荐

05-07 17:58
门头沟学院 Java
wuwuwuoow:1.简历字体有些怪怪的,用啥写的? 2.Redis 一主二从为什么能解决双写一致性? 3.乐观锁指的是 SQL 层面的库存判断?比如 stock > 0。个人认为这种不算乐观锁,更像是乐观锁的思想,写 SQL 避免不了悲观锁的 4.奖项证书如果不是 ACM,说实话没什么必要写 5.逻辑过期时间为什么能解决缓存击穿问题?逻辑过期指的是什么 其实也没什么多大要改的。海投吧
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务