1.题目描述
小明设计了一种文章加密的方法:对于每个字母 c,将它变成某个另外的字符 Tc。下表给出了字符变换的规则:
例如,将字符串 YeRi 加密可得字符串 EaFn。
小明有一个随机的字符串,加密后为
EaFnjISplhFviDhwFbEjRjfIBBkRyY
(由 30 个大小写英文字母组成,不包含换行符),请问原字符串是多少?
(如果你把以上字符串和表格复制到文本文件中,请务必检查复制的内容是否与文档中的一致。在试题目录下有一个文件 str.txt,第一行为上面的字符串,后面 52 行依次为表格中的内容。)
答案提交
这是一道结果填空题,你只需要算出结果后提交即可。本题的结果为一个只包含 30 个大小写英文字母的字符串,在提交答案时只填写这个字符串,填写多余的内容将无法得分。
2.思路
方法一:首先把加密前的字母和加密后的字母(Tc那一列)列出来 一一对应就ok ,但容易出错
方法二:将字符串转化成字符数组,然后将加密后的字符串去得出在对应法则中的字符,最后根据加密后的字符,推出原字符
toCharArray() 方法将字符串转换为字符数组。
package 蓝桥杯;
public class 解密 {
public static void main(String[] args) {
// TODO Auto-generated method stub
String str=new String("TalorSwift");
System.out.println(str.toCharArray());
//输出TalorSwift
}
}
3.代码实现
package 蓝桥杯;
public class 解密 {
public static void main(String[] args) {
// TODO Auto-generated method stub
/*
* String str=new String("TalorSwift"); System.out.println(str.toCharArray());
*/
String s="EaFnjISplhFviDhwFbEjRjfIBBkRyY";//加密后的字符串
char[] arr=s.toCharArray();//将字符串转换为字符数组
String s1="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";//加密规则 加密前的字符串
String s2="yxmdacikntjhqlgoufszpwbrevYXMDACIKNTJHQLGOUFSZPWBREV";//加密规则 加密后的字符串
String s3="";//解密后的字符
for(int i=0;i<arr.length;i++)
{
int j=s2.indexOf(arr[i]);//输出当前字符数组在加密后字符s2中的位置
//System.out.print(j+" ");
s3=s3+s1.substring(j,j+1);
//""字符变成字符串,substring取子串,每个j对应s1中的某个字母,找出原字符串所对应的字符
}
System.out.print(s3);
}
}
4.答案
YeRikGSunlRzgDlvRwYkXkrGWWhXaA