算法题_单词加密_python实现

该博客介绍了如何实现一个简单的字符串加密算法,通过将每个字母替换为其字母表中后第k个字母,循环处理大小写字母。示例中,输入字符串'asAf$ccz'和加密指数3,输出加密后的字符串为'ddeB$ffc'。此算法对非字母字符保持不变,并处理了字母循环的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/单词加密。输入一个字符串和一个非负整数k,对字符串中的每一个字母,
用字母表中其后的第k个字母代替,不够k个时再从字母a循环计数。
例如k=3是,a用d代替,A用D代替,x用a代替,y用b代替,保持大小写不变。
字符串中的非字母字符不变。字符串的长度不超过100。
输入:一个字符串(无空格)和非负整数k,之间用空格分隔
输出:加密的字符串。
/

# todo 测试输入
str_in = 'asAf$ccz'
str_num = int('3')

# todo 解答
import string


lower_str = string.ascii_lowercase
upper_str = string.ascii_uppercase
str_out, len_str_in = '', len(lower_str)

for i in range(len(str_in)):
    if str_in[i] in lower_str:
        index = lower_str.index(str_in[i]) + str_num

        if index > len_str_in:
            str_out += lower_str[index - len_str_in]
        else:
            str_out += lower_str[index]

    elif str_in[i] in upper_str:
        index = upper_str.index(str_in[i]) + str_num

        if index > len_str_in:
            str_out += upper_str[index - len_str_in]
        else:
            str_out += upper_str[index]

    else:
        str_out += str_in[i]

print(str_out)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值