凯撒密码-java

本文介绍了密码学中最简单的加密技术——恺撒密码。该技术通过替换加密的方式,将明文中的字母按照固定数目偏移后替换为密文。文章提供了一个Java实现的例子,展示了如何使用偏移量对文本进行加密。
摘要由CSDN通过智能技术生成

密码学中,恺撒密码(英语:Caesar cipher),或称恺撒加密恺撒变换变换加密,是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推。

 

例如输入明文:HelloWorld   偏移量为3

此时输出密文:KhoorZruog

以下是用java代码实现凯撒密码的加密解密:

//凯撒密码:
//输入明文:abc 输入密钥:2
//输出密文:cde
import java.util.Scanner;

public class KaiSaPassWord {
    public static void main(String[] args) {
        System.out.print("请输入密文:");
        Scanner scanner = new Scanner(System.in);
        String string=scanner.next();
        System.out.print("请输入秘钥:");//秘钥即偏移量
        int key=scanner.nextInt();
        key=key%26;//key的绝对值可能会大于26
        System.out.println("-------------------------");
        System.out.print("明文是:");
        char ch[]=string.toCharArray();//将字符串转换为字符数组
        for (int i = 0; i < ch.length; i++) {
            if (ch[i]>='a'&&ch[i]<='z') {
                ch[i] = (char)(((ch[i]-'a')+key)%26+'a');
            }
            else if(ch[i]>='A'&&ch[i]<='Z'){
                ch[i] = (char)(((ch[i]-'A')+key)%26+'A');
            }
            System.out.print(ch[i]);
        }
    }
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值