0, ‘b ->1,…, 1 ->26, 2 ->27..."/>
溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java實現(xiàn)仿射密碼加密解密

發(fā)布時間:2020-09-24 06:48:07 來源:腳本之家 閱讀:200 作者:降妖問問你敢不敢 欄目:編程語言

本文實例為大家分享了java實現(xiàn)仿射密碼加密解密的具體代碼,供大家參考,具體內(nèi)容如下

加密:將明文轉(zhuǎn)化為對應的數(shù)字,如 ‘a(chǎn)'-> 0, ‘b'->1,…,'1'->26,'2'->27,…然后將數(shù)字進行仿射運算,求取出來的數(shù)字再轉(zhuǎn)化為字符。即 密文=(K1*明文+K2)mod36

解密:密文轉(zhuǎn)化為對應數(shù)字,然后進行仿射的逆運算,得到對應數(shù)字,然后將其轉(zhuǎn)化為字符明文。解密 K3是K1的乘法逆元

import java.util.Scanner;

public class Affine{
 public static void main(String[] args) {
 char[] form = {'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',
  'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '0'
  , '1', '2', '3', '4', '5', '6', '7', '8', '9'};
 Scanner sc = new Scanner(System.in);
 System.out.println("請輸入待加密的明文:");
 String MingWen = sc.nextLine();
 MingWen=MingWen.toUpperCase();//將輸入的明文全部大寫
 final int K1 = 103;
 final int K2 = 103;
 final int K3 = 31;
 int [] cipherNum=new int[MingWen.length()];//用來存儲數(shù)字化的密文
 encryption(MingWen,form,K1,K2,cipherNum);
 decryption(form,MingWen,K2,K3,cipherNum);

 }
 public static void encryption(String MingWen,char[] form,int K1,int K2,int[] cipherNum){
 //第一步:將明文存入數(shù)組
 char[] pla=new char[MingWen.length()];
 for (int i = 0; i <MingWen.length() ; i++) {
  pla[i]=MingWen.charAt(i);
 }//已將明文存入字符數(shù)組pla中
 //第二步:通過腳標找到明文中每個字符對應的數(shù),參與加密運算
 int[] MingWenNumber=new int[pla.length];
 for (int i = 0; i <pla.length ; i++) {
  for (int j = 0; j <form.length ; j++) {
  if (form[j]==pla[i]) {
   MingWenNumber[i] = j;
  }
  }
 }
 //通過腳標將明文全部轉(zhuǎn)化為數(shù)字
 char[] cipher = new char[MingWen.length()];//cipher密碼數(shù)組 用來存儲密文
 for (int i = 0; i <MingWen.length() ; i++) {
  int a= Math.floorMod((K1*MingWenNumber[i]+K2),36);
  cipherNum[i]=a;
  cipher[i]=form[a];
  //計算密文并存入數(shù)組中
 }
 System.out.println("加密結(jié)果是:");
 System.out.println(cipher);
 }

 public static void decryption(char[] form,String Mingwen,int K2,int K3,int[] cipherNum){
 char[] JieMI=new char[Mingwen.length()];
 for (int i =0;i<Mingwen.length();i++){
  JieMI[i]=form[Math.floorMod(K3*(cipherNum[i]-K2),36)];
 }
 System.out.println("解密結(jié)果是:");
 System.out.println(JieMI);
 }
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI