计算机网络实验六

package test;

import java.util.Scanner;

public class test1 {

    private static final String ALPHABET = "abcdefghijklmnopqrstuvwxyz";

    public static void main(String[] args) {
        String encryptedText="";
        Scanner sys =new Scanner(System.in);
        System.out.println("请输入明文");
        String plainText=sys.next();
        System.out.println("请输入密钥a");
        int keyA=sys.nextInt();
        System.out.println("请输入密钥b");

        int keyB=sys.nextInt();
        if(gcd(keyA,keyB)==1){
             encryptedText = encrypt(plainText, keyA, keyB);
             System.out.println("加密后的文本: " + encryptedText);
        }
        else {
            System.out.println("密钥必须互素");
        }
        if(gcd(keyA,keyB)==1){
            String decryptedText = decrypt(encryptedText, keyA, keyB);
            System.out.println("解密后的文本: " + decryptedText);
        }
       else {
            System.out.println("密钥必须互素");
        }


    }
    public static String encrypt(String text, int keyA, int keyB) {
         StringBuilder result=new StringBuilder();
         for(char c: text.toCharArray()){
           if(Character.isLetter(c)){
               int position=ALPHABET.indexOf(Character.toLowerCase(c));
               char encryptedChar=ALPHABET.charAt((keyA*position+keyB)%ALPHABET.length());
               if(Character.isUpperCase(c)){
                   result.append(Character.toUpperCase(encryptedChar));
               }else {
                   result.append(encryptedChar);
               }
           }else {
               result.append(c);
           }
        }
         return result.toString();
    }
    public static String decrypt(String text, int keyA, int keyB) {
        StringBuilder result = new StringBuilder();

        int modInverse = 0;
        for (int i = 0; i < ALPHABET.length(); i++) {
            if ((keyA * i) % ALPHABET.length() == 1) {
                modInverse = i;
                break;
            }
        }
        for(char c:text.toCharArray()){
            if (Character.isLetter(c)){
                int position=ALPHABET.indexOf(Character.toLowerCase(c));
                char decryptedChar=ALPHABET.charAt(modInverse * (position - keyB + ALPHABET.length()) % ALPHABET.length());
                if(Character.isUpperCase(c)){
                    result.append(Character.toUpperCase(decryptedChar));
                }else {
                    result.append(decryptedChar);
                }
            }else {
                result.append(c);
            }
        }
        return result.toString();
    }
    public static int gcd(int a, int b) {
        while (b != 0) {
            int temp = b;
            b = a % b;
            a = temp;
        }
        return a;
    }

    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值