凯撒密码用c语言实现

凯撒密码是历史上最简单的加密方式之一,它基于一种替换方法,即将明文中的每个字母都替换成它之后的第 N 个字母。下面是一个简单的 C 语言实现:

复制代码
#include <stdio.h>
#include <string.h>

// 加密函数,plaintext 为明文,key 为加密密钥
void encrypt(char plaintext[], int key) {
    int len = strlen(plaintext);
    for (int i = 0; i < len; i++) {
        if (plaintext[i] >= 'a' && plaintext[i] <= 'z') {
            // 处理小写字母
            plaintext[i] = (plaintext[i] - 'a' + key) % 26 + 'a';
        } else if (plaintext[i] >= 'A' && plaintext[i] <= 'Z') {
            // 处理大写字母
            plaintext[i] = (plaintext[i] - 'A' + key) % 26 + 'A';
        }
    }
}

// 解密函数,ciphertext 为密文,key 为加密密钥
void decrypt(char ciphertext[], int key) {
    int len = strlen(ciphertext);
    for (int i = 0; i < len; i++) {
        if (ciphertext[i] >= 'a' && ciphertext[i] <= 'z') {
            // 处理小写字母
            ciphertext[i] = (ciphertext[i] - 'a' - key + 26) % 26 + 'a';
        } else if (ciphertext[i] >= 'A' && ciphertext[i] <= 'Z') {
            // 处理大写字母
            ciphertext[i] = (ciphertext[i] - 'A' - key + 26) % 26 + 'A';;
        }
    }
}

int main() {
    char plaintext[100], ciphertext[100];
    int key;
    
    // 读取明文和密钥
    printf("Enter plaintext: ");
    gets(plaintext);
    printf("Enter key: ");
    scanf("%d", &key);
    
    // 加密
    strcpy(ciphertext, plaintext);
    encrypt(ciphertext, key);
    printf("Ciphertext: %s\n", ciphertext);
    
    // 解密
    decrypt(ciphertext, key);
    printf("Decrypted plaintext: %s\n", ciphertext);
    
    return 0;
}

在这个例子中,我们将用户输入的明文和密钥传递给 encrypt 函数,该函数将加密结果存储在了 ciphertext 数组中,我们再将其打印出来。然后,我们调用 decrypt 函数并将 ciphertext 和密钥作为参数传递给它,这个函数将在原地解密密文并将结果存储在 ciphertext 中,最后我们将其打印出来以得到解密后的明文。

需要注意的是,在处理小写和大写字母时要分别加上 'a' 或 'A',并且需要对数字进行模运算以确保使用正常的字母序,使用了 gets 函数读取用户输入,需要小心输入超过字符数组容量时可能导致的缓冲区溢出问题。

相关推荐
小龙报7 小时前
《嵌入式成长系列之51单片机 --- Keil5创建工程》
c语言·开发语言·c++·单片机·嵌入式硬件·51单片机·学习方法
无限进步_7 小时前
【C语言】贪吃蛇游戏设计思路深度解析:从零开始理解每个模块
c语言·开发语言·c++·git·游戏·github·visual studio
听风吟丶7 小时前
Java 函数式编程深度实战:从 Lambda 到 Stream API 的工程化落地
开发语言·python
rainFFrain7 小时前
qt显示类控件--- Label
开发语言·qt
渡我白衣7 小时前
深入理解 OverlayFS:用分层的方式重新组织 Linux 文件系统
android·java·linux·运维·服务器·开发语言·人工智能
西游音月7 小时前
(6)框架搭建:Qt实战项目之主窗体快捷工具条
开发语言·qt
waves浪游8 小时前
进程概念(上)
linux·运维·服务器·开发语言·c++
百***92658 小时前
java进阶1——JVM
java·开发语言·jvm
杜子不疼.8 小时前
【C++】 map/multimap底层原理与逻辑详解
开发语言·c++
司铭鸿8 小时前
数学图论的艺术:解码最小公倍数图中的连通奥秘
运维·开发语言·算法·游戏·图论