仿射变换加密

根据公式c = Ea, b(m) ☰ a * m + b (mod 26);

如果已知a, b, 加密非常简单,代码如下:

#include <bits/stdc++.h>
using namespace std;
int a, b;
void Input()
{
    int p, val;
    char key;
    char key_2[1010];
    cout << "请输入a, b的值(中间以空格分开)" << endl;
    scanf("%d %d", &a, &b);
    cout << "一次输入一个字符请输入 1 否则请输入 2" << endl;
    scanf("%d", &p);
    if(p == 1)
    {
        getchar();
        while(scanf("%c", &key) != EOF)
        {
            if(key != '\n')
            {
             val = ((key - 'A') * a + b) % 26;
            key = 'A' + val;
            cout << "val = " << val << " key =  " << key << endl;
            }
        }
    }
    else
        {
            getchar();
            gets(key_2);
            int len = strlen(key_2);
            for(int i = 0; i < len; ++i)
            {
                if(key_2[i] >= 'A' && key_2[i] <= 'Z')
                {
                 val = ((key_2[i] - 'A') * a + b) % 26;
                 key_2[i] = val + 'A';
                }
            }
            cout << key_2 << endl;
        }

}
int main()
{
    Input();
}

仿射变换加密解密是一种基于数学运算的加密解密方法,可以通过一系列简单的数学运算来加密和解密数据。下面是一个基于Java的仿射变换加密解密的实现代码: ```java import java.util.Scanner; public class AffineCipher { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.print("请输入要加密的字符串:"); String plainText = scanner.nextLine(); int a = 5; // 仿射变换参数a int b = 8; // 仿射变换参数b // 加密 String cipherText = encrypt(plainText, a, b); System.out.println("加密后的字符串为:" + cipherText); // 解密 String decryptedText = decrypt(cipherText, a, b); System.out.println("解密后的字符串为:" + decryptedText); } /** * 加密方法 * @param plainText 要加密的字符串 * @param a 仿射变换参数a * @param b 仿射变换参数b * @return 加密后的字符串 */ public static String encrypt(String plainText, int a, int b) { StringBuilder stringBuilder = new StringBuilder(); for (int i = 0; i < plainText.length(); i++) { char ch = plainText.charAt(i); if (ch >= 'a' && ch <= 'z') { int x = ch - 'a'; int y = (a * x + b) % 26; char encrypted = (char) ('a' + y); stringBuilder.append(encrypted); } else if (ch >= 'A' && ch <= 'Z') { int x = ch - 'A'; int y = (a * x + b) % 26; char encrypted = (char) ('A' + y); stringBuilder.append(encrypted); } else { stringBuilder.append(ch); } } return stringBuilder.toString(); } /** * 解密方法 * @param cipherText 要解密的字符串 * @param a 仿射变换参数a * @param b 仿射变换参数b * @return 解密后的字符串 */ public static String decrypt(String cipherText, int a, int b) { StringBuilder stringBuilder = new StringBuilder(); // 计算a的逆元a' int aInverse = -1; for (int i = 0; i < 26; i++) { if ((a * i) % 26 == 1) { aInverse = i; break; } } for (int i = 0; i < cipherText.length(); i++) { char ch = cipherText.charAt(i); if (ch >= 'a' && ch <= 'z') { int y = ch - 'a'; int x = (aInverse * (y - b + 26)) % 26; char decrypted = (char) ('a' + x); stringBuilder.append(decrypted); } else if (ch >= 'A' && ch <= 'Z') { int y = ch - 'A'; int x = (aInverse * (y - b + 26)) % 26; char decrypted = (char) ('A' + x); stringBuilder.append(decrypted); } else { stringBuilder.append(ch); } } return stringBuilder.toString(); } } ``` 上面的代码实现了一个简单的仿射变换加密解密方法,可以加密和解密字符串。其中,仿射变换的参数a和b可以自己定义,这里默认设置为a=5、b=8。在实际应用中,可以根据需要调整这两个参数,以获得更好的加密效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值