【问题描述】
在情报传递过程中,为了防止情报被截获,往往需要对情报用一定的方式加密,简单的加密算法虽然不足以完全避免情报被破译,但仍然能防止情报被轻易的识别。我们给出一种最简的的加密方法,对给定的一个字符串,把其中从a-y,A-Y的字母用其后继字母替代,把z和Z用a和A替代,则可得到一个简单的加密字符串。
【输入形式】
可能有多组测试数据。每组测试数据的第一行是字符串的数目n,其余n行每行一个字符串,每个字符串长度小于80个字符。
【输出形式】
对于每组数据,输出每行字符串的加密字符串。
【样例输入】
1
Hello! How are you!
【样例输出】
Ifmmp! Ipx bsf zpv!
代码说明:这道题其实考的就是for循环还有while循环的结合和if判断,另外还有输入的nextInt()和nextLine()方法的具体内涵(这个在我转载的另一篇文章中有详细解释),不是很难,下面放代码。因为学校的oj不能有注释,所以就没写注释,但还是看得懂的。
import java.util.Scanner;
public class Secret {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner in = new Scanner(System.in);
int num = in.nextInt();
in.nextLine();
while(num>0)
{
String a = in.nextLine();
char b[] = a.toCharArray();
for(int i = 0;i<a.length();i++)
{
if(b[i]<='Y' && b[i]>='A' || b[i] <='y' && b[i]>='a')
{
b[i]+=1;
}
else if (b[i] == 'Z')
{
b[i] = 'A';
}
else if(b[i] == 'z')
{
b[i] = 'a';
}
}
System.out.println(b);
num = num-1;
}
}
}