凯撒加密算法,Java代码实现

🎉 前言

今天来写一个简单的凯撒加密算法实现。

🎉 代码

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);
    }
}

注释写得还是比较详细的,一些注意点也提到了,大家可以在此基础上进行扩展。今后也会不定期更新密码学的内容,大家可以关注博主,支持一下🎊。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋窗7

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值