Python Challenge 谜题1

这个题目我初一看是要我把K变为M,O变为Q,E变为G,后来才发现不是这样,难怪作者说:“everybody thinks twice before solving this.”

其实是要做一个类似编码解码的问题,就是把abcdefghijklmnopqrstuvwxyz变为cdefghijklmnopqrstuvwxyzab
有了这个思路就好做了
看代码

# -*- coding: utf-8 -*- 
__author__   =   " hujinpu "  
  
import  string 
  
# 产生一个用来转换的编码表,是一个长为256bit的字符串 
table  =  string.maketrans(string.ascii_lowercase, string.ascii_lowercase[ 2 :] + string.ascii_lowercase[: 2 ]) 
  
oldstr 
=   " g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq ypc dmp. bmgle gr gl zw fylb gq glcddgagclr ylb rfyr'q ufw rfgq rcvr gq qm jmle. sqgle qrpgle.kyicrpylq() gq pcamkkclbcb. lmu ynnjw ml rfc spj. "  
  
# 根据编码表变换字符串 
newstr  =  oldstr.translate(table) 
# 作一定的格式化输出 
print  ( " " ).join(newstr.split( " . " )) 
  
oldurl 
=   " map "  
newurl 
=  oldurl.translate(table)
还可以不用table

oldstr  =   " g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq ypc dmp. bmgle gr gl zw fylb gq glcddgagclr ylb rfyr'q ufw rfgq rcvr gq qm jmle. sqgle qrpgle.kyicrpylq() gq pcamkkclbcb.  lmu ynnjw ml rfc spj. "  
newstr 
=   ""  
for  x  in  oldstr: 
    
if  ord(x)  >=  ord( ' a ' and  ord(x)  <=  ord( ' z ' ): 
        newstr 
+=  chr((ord(x)  +   2   -  ord( ' a ' ))  %   26   +  ord( ' a ' )) 
    
else
        newstr 
+=  x 
print  ( " " ).join(newstr.split( " . " ))

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值