密码学--多表替代算法实现

本文深入探讨了密码学中的多表替代算法,详细解释了其实现原理,为理解加密过程提供了关键信息。
摘要由CSDN通过智能技术生成

多表替代的实现

原理

在这里插入图片描述

package MiMaXue;

import java.util.Scanner;

public class DuoBiaoTiHuan1{
   
	public static void main(String[] args){
   
		Scanner sc=new Scanner(System.in);
		System.out.print("请输入一个分组有几个字母:");
		int h=sc.nextInt();
		System.out.print("请输入模数:");
		int N=sc.nextInt();
		//输入密钥矩阵A、B
		System.out.println("请输入密钥矩阵A:");
		int[][] A=new int[h][h];
		for(int i=0;i<A.length;i++){
   
			for(int j=0;j<A[0].length;j++){
   
				A[i][j]=sc.nextInt();
			}
		}
		System.out.println("请输入密钥矩阵B:");
		int[][] B=new int[h][1];
		for(int i=0;i<h;i++){
   
			B[i][0]=sc.nextInt();
		}
		System.out.print("请输入将要加密的字符串:");
	    String M=sc.next();
	    char[] M1=M.toCharArray();
	    int[] M2=new int[M1.length];
	    //将明文的字母转化为对应的数字
	    for(int i=0;i<M1.length;i++){
   
	    	M2[i]=M1[i]-'A';
	    }
	    int[][] mi=new int[h][1];//用于将明文分组
	    int[][] C=new int[M1.length][1];//加密后的数组
	    int n=0;
	    int m=0;
	    //分组加密,每组有h个元素
        while(n<M2.length){
   
        	for(int i=0;i<h;i++){
   
        		mi[i][0]=M2[n++];
        	}
        	//加密
        	int[][] D=encryption(mi,A,B,N);
        	for(int i=0;i<D.length;i++){
   
        		C[m++][0]=D[i][0];
        	}
        }
        System.out.print("输出加密后的字符串:");
        for(int i=0;i<C.length
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值