凯撒加密、解密算法
古罗马皇帝凯撒在打仗时曾经使用过以下方法加密军事情报,主要方法就是字母错位,下面这张图加密方法就是错三个位来实现加密功能
(1) 设计思想:
- 由于输入的是一串英文字符,所以我们用String类来编写,况且String类有许多方法可以调用
- 错位需要对每个字符进行操作,可以把字符串转换为字符数组,调用的是string类的toCharArray方法
- 由于string类也是采用Unicode字符集,所以我们进行错位操作时只需读取一个字符,然后与数字3相加,再转换为char类型,就实现了错3位加密操作,解密则减3.
- 在加密操作中,如果加密的是字母表最后三个,则必须实现循环操作,即X加密后是A,Y加密后是B,Z加密后是C,实现这个就要用到ASCII码,当读到XYZ时,加密则是减去23后转换为char类型,当然,解密时读到ABC加上23即可
(2) 程序流程图:
(3) 源代码:
package temp; import java.util.Scanner; public class Tast2 { public static char[] encrypation(String str) {//加密方法 char chararry[] = str.toCharArray();//把字符串转化为字符数组 for(int i =0; i< str.length(); i++) { //当读到字母表后3位时,加密后是字母表前三位 if(str.charAt(i) >= 88 && str.charAt(i) <= 90) {//大写时 chararry[i] = (char)(str.charAt(i) - 23); } else if(str.charAt(i) >= 120 && str.charAt(i) <= 122) {//小写时 chararry[i] = (char)(str.charAt(i) - 23); } //一般加密方法 else { chararry[i]= (char) (str.charAt(i) + 3) ; } } return chararry; } public static char[] deciphering(String str) {//j解密方法 char chararry[] = str.toCharArray(); for(int i =0; i< str.length(); i++) { //当读到字母表前3位时,加密后是字母表后三位 if(str.charAt(i) >= 65 && str.charAt(i) <= 67) {//大写时 chararry[i] = (char)(str.charAt(i) + 23); } else if(str.charAt(i) >= 97 && str.charAt(i) <= 99) {//小写时 chararry[i] = (char)(str.charAt(i) + 23); } //一般解密密方法 else { chararry[i]= (char) (str.charAt(i) - 3) ; } } return chararry; } public static void main(String[] args) { Scanner imput1 = new Scanner(System.in); Scanner imput2 = new Scanner(System.in); System.out.println("*****************************"); System.out.println("*****加密字符串输入---1---"); System.out.println("*****解密字符串输入---2---"); System.out.println("*****************************"); System.out.print("请输入:"); int flag = imput1.nextInt(); System.out.print("请输入一个英文字符串:"); String string = imput2.nextLine(); if(flag == 1) { System.out.print("经过加密后为:"); for(int i =0;i <string.length(); i++) { System.out.print(Tast2.encrypation(string)[i]); } } if(flag == 2) { System.out.print("经过解密后为:"); for(int i =0;i <string.length(); i++) { System.out.print(Tast2.deciphering(string)[i]); } } imput1.close(); imput2.close(); } }
(4) 结果截图:
附录:String类型常用方法整理:
(1)String.equals():
例:str1.equals(str2);如果字符串st1的内容与字符串str2内容相同,则返回true,否则返回false
(2)String.length():
例:str1.length();返回字符串str1的长度,或者说是大小
(3)String.charAt():
例:str1.charAt(index);返回字符串str1中下标为index的字符,下标从0开始计数
(4)String.getChars():
例:str1.getChars(0,5,charArray,0);把字符串str1中从下标0开始到下标5结束的子串拷贝到字符数组charArray中,字符数组的起始下标为0
(5)Sting.replace():
例:str1.replace(oldChar,newChar);返回一个新字符,它拥有与字符串str1相同的字符,但是把每一个oldCase字符都替换为newCase字符
(6)Sting.toUpperCase():
例:str1.toUpperCase();返回一个新字符,它拥有与字符串str1相同的字符,但是把所有的小写字母都转换成了大写
(7)Sting.toLowerCase():
例:str1.toLowerCase();返回一个新字符,它拥有与字符串str1相同的字符,但是把所有的大写字母都转换成了小写
(8)Sting.trim():
例:str1.trim();返回一个新字符,它拥有与字符串str1相同的字符,但是删除了字符串str1的前后空白字符,(空白字符包括空格、制表符以及转行字符)
(9)String.toCharArray():
例:chararray[] = str1.toCharArray();把字符串str1转换成字符数组,并保存在chararrayp[]中