凯撒加密解密(java字母移位)
1.设计思想:加密就是将字符数据转化为ASC码表中的数字,a—w之间通过加3之后再转化为字符型输出,x—z之间通过转化为ASC码表中的数字后减去23再转化为字符型输出。解密就是将字符数据转化为ASC码表中的数字,d—z之间通过减去3之后再转化为字符型输出,a—c之间通过转化为ASC码表中的数字后加23再转化为字符型输出。
2.程序流程图
3.程序源码
import java.util.Scanner;
public class Code {
//严羽卿 凯撒加密与解密 2015 10 23
public static void main(String[] args) {
// TODO Auto-generated method stub
String input = null;
Scanner sc = new Scanner(System.in);
System.out.println("请输入字母:");
input = sc.next();
StringBuffer code = new StringBuffer();
Scanner sc1=new Scanner(System.in);
System.out.println("加密请按1,解密请按2:");
int p;
p=sc1.nextInt();
if(p==1)
{
System.out.println("加密之后为:");
for(int i = 0;i < input.length();i++)
{
char x = input.charAt(i);
if(x >= 'a' && x <= 'w')
{
x = (char)(x+3);
code.append(x);
}
if(x >= 'x' && x <= 'z')
{
x=(char)(x-23);
code.append(x);
}
if(x >= 'A' && x <= 'W')
{
x = (char) (x+3);
code.append(x);
}
if(x >= 'X' && x <= 'Z')
{
x=(char)(x-23);
code.append(x);
}
}
}
if(p==2)
{
System.out.println("解密:");
for(int i = 0;i < input.length();i++)
{
char x = input.charAt(i);
if(x >= 'a' && x <= 'c')
{
x=(char)(x+23);
code.append(x);
}
else if(x >= 'd' && x <= 'z')
{
x = (char)(x-3);
code.append(x);
}
else if(x >= 'A' && x <= 'C')
{
x=(char)(x+23);
code.append(x);
}
else if(x >= 'D' && x <= 'Z')
{
x = (char) (x-3);
code.append(x);
}
}
}
System.out.println(code);
}
}
4.结果截图
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步