python challenge challenge1 之java解

本文解析了Python Challenge网站上的第1题,介绍了如何通过将字母右移两位来解码特定字符串的方法。提供了完整的Java代码实现,展示了字符解码的过程。

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

python challeng见[url]www.pythonchallenge.com[/url]
第0题就不解了,就是2的38次方
从第1题开始
第1题是密码转换
解码原则:每个字母都右移2位


public class Challenge1Decode {

public static void main(String[] args) {
String encodeStr = "map";
System.out.println(decodeStr(encodeStr));

String x = "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.";
String alphabet = "abcdefghijklmnopqrstuvwxyz";
String out = "";
for (int i = 0; i < x.length(); i++) {
if (alphabet.indexOf(x.charAt(i)) == -1)
out += x.charAt(i);
else
out += alphabet.charAt((alphabet.indexOf(x.charAt(i)) + 2) % 26);
}
System.out.println(out);
}

public static String decodeStr(String str){
char[] charArr = str.toCharArray();
StringBuilder builder = new StringBuilder();
for(char oldChar : charArr){
char newChar = decodeChar(oldChar);
builder.append(newChar);
}
return builder.toString();
}

public static char decodeChar(char oldChar){
if(oldChar >= 'a' && (int)oldChar <= 'x' ){
return (char)(oldChar + 2);
}else if(oldChar == 'y'){
return 'a';
}else if(oldChar == 'z'){
return 'b';
}else{
return oldChar;
}

}


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值