#include <iostream>
#include<iomanip>
using namespace std;
int main()
{
string plaintext = "this cryptosystem is not secure";//明文
string secretKey = "cipher";//密钥
cout << plaintext << endl;
string ciphertext="";//密文
int space = 0;//空格数
for (int i = 0; i < plaintext.length(); i++)
{
if (plaintext[i] >= 'a' && plaintext[i] <= 'z')
{
cout << std::left << setw(3) << plaintext[i];
}
else
cout << "\t";
}
cout << endl;
//生成密钥
space = 0;
for (int i = 0; i < plaintext.length(); i++)
{
if (plaintext[i] >= 'a' && plaintext[i] <= 'z')
{
cout << std::left << setw(3) << secretKey[(i-space)% secretKey.length()];
}
else
{
space++;
cout << "\t";
}
}
cout << endl;
维吉尼亚密码(仅带空格26英文字母段)
最新推荐文章于 2022-12-16 15:26:28 发布
本文深入探讨了维吉尼亚密码的加密原理和解密过程,这是一种使用多表替换的古典密码学方法。通过改变密钥,维吉尼亚密码提供了相对于简单替换密码更高的安全性。同时,文章还介绍了在现代信息安全中,维吉尼亚密码的局限性和其对现代加密技术的影响。
摘要由CSDN通过智能技术生成