【C语言】单表交换密码的加密解密

单表交换密码是一种简单但不够安全的加密方法,它适用于对简单文本进行加密,但不适用于对于保密性要求较高的数据。使用时需要注意,密钥(即密钥表)应为字母表的一个排列,它将明文中的每个字母映射到一个不同的字母上。用户输入密钥时,应保证其长度为26,并且包含字母表的每个字母,且每个字母仅出现一次。在实际应用中,应使用更为复杂和安全的加密算法来保护数据的安全 

解题思路:

先接收用户输入的明文和密钥表,创建一个加密函数monoalphabetic_encrypt,该函数有两个参数:plainText是待解密的密文字符串,key是密钥表。加密思路为:用户输入明文和加密密钥,密钥是一个字母表的排列-->根据密钥,将明文中的每个字母替换为密钥表中对应位置的字母-->加密完成后,输出密文。

#include <stdio.h>
#include <string.h>

// 单表交换加密函数
void monoalphabetic_encrypt(char *plaintext, char *key) {
    int i;
    for (i = 0; i < strlen(plaintext); i++) {
        // 加密大写字母
        if (plaintext[i] >= 'A' && plaintext[i] <= 'Z') {
            plaintext[i] = key[plaintext[i] - 'A'];
        }
        // 加密小写字母
        else if (plaintext[i] >= 'a' && plaintext[i] <= 'z') {
            plaintext[i] = tolower(key[plaintext[i] - 'a']);
        }
    }
}

// 单表交换解密函数
void monoalphabetic_decrypt(char *ciphertext, char *key) {
    int i;
    for (i = 0; i < strlen(ciphertext); i++) {
        // 解密大写字母
        if (ciphertext[i] >= 'A' && ciphertext[i] <= 'Z') {
            int j;
            for (j = 0; j < 26; j++) {
                if (key[j] == ciphertext[i]) {
                    ciphertext[i] = 'A' + j;
                    break;
                }
            }
        }
        // 解密小写字母
        else if (ciphertext[i] >= 'a' && ciphertext[i] <= 'z') {
            int j;
            for (j = 0; j < 26; j++) {
                if (tolower(key[j]) == ciphertext[i]) {
                    ciphertext[i] = 'a' + j;
                    break;
                }
            }
        }
    }
}

int main() {
    char plaintext[100], ciphertext[100], key[26];
    int i;

    printf("Enter the plaintext: ");
    fgets(plaintext, sizeof(plaintext), stdin);

    printf("Enter the key (a permutation of the alphabet): ");
    fgets(key, sizeof(key), stdin);

    // 去除密钥中的换行符
    key[strcspn(key, "\n")] = '\0';

    // 加密过程
    strcpy(ciphertext, plaintext);
    monoalphabetic_encrypt(ciphertext, key);
    printf("Encrypted text: %s\n", ciphertext);

    // 解密过程
    monoalphabetic_decrypt(ciphertext, key);
    printf("Decrypted text: %s\n", ciphertext);

    return 0;
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱因斯坦乐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值