🎉 前言
今天来写一个简单的凯撒加密算法实现。
🎉 代码
import java.util.*;
class Encode{
public static void main(String[] args) {
String m = "Modern cryptography";
String c = "";
int count = 0;
List<Integer> arry = new ArrayList<>();
//统一转换为小写字符
m = m.toLowerCase();
//将字符转换成数字并存在数组里
while (count < m.length()) {
//处理空格字符
if(String.valueOf(m.charAt(count)).equals(" ")){
count++;
continue;
}
int srcNum = m.charAt(count) - 97;//字符转换为数字
int dstNum = (srcNum + 3) % 26;//凯撒加密算法
arry.add(dstNum);
count++;
}
//将数组里的数字转换成加密字符
for(int i=0;i<arry.size();i++){
char tempChar = (char)(arry.get(i).intValue() + 97);//注意加上97
c += String.valueOf(tempChar);
}
System.out.println("加密结果:"+ c);
//以下为解密
m = "";
count = 0;
arry.clear();
while (count < c.length()) {
int srcNum = c.charAt(count) - 97;//字符转换为数字
int dstNum = (srcNum - 3) % 26;//凯撒加密算法
//处理负数的情况
if(dstNum < 0){
dstNum+=26;
}
arry.add(dstNum);
count++;
}
//将数组里的数字转换成加密字符
for(int i=0;i<arry.size();i++){
char tempChar = (char)(arry.get(i).intValue() + 97);//注意加上97
m += String.valueOf(tempChar);
}
System.out.println("解密结果:"+ m);
}
}
注释写得还是比较详细的,一些注意点也提到了,大家可以在此基础上进行扩展。今后也会不定期更新密码学的内容,大家可以关注博主,支持一下🎊。