C语言键盘输入5个字母的明文,加密成密文输出。加密的方法是该字母的ASCII值加4.
时间: 2023-05-11 22:03:17 浏览: 145
可以使用以下代码实现:
```c
#include <stdio.h>
int main() {
char plaintext[6];
printf("请输入5个字母的明文:");
scanf("%s", plaintext);
for (int i = 0; i < 5; i++) {
plaintext[i] += 4;
}
printf("加密后的密文为:%s\n", plaintext);
return 0;
}
```
这段代码首先读入用户输入的明文,然后对每个字母的ASCII值加4,最后输出加密后的密文。注意,这里没有进行任何错误处理,比如输入的不是5个字母等情况,需要根据实际情况进行处理。
相关问题
c语言编写一个程序,将一个包含大小写字母的纯字母密文串转换为纯大写字母的明文串输出。 加密规则为: 密文字母转换为其对应大写字母的后面第3个大写字母( x y , z 转换为 A , B c )
以下是一个简单的 C 语言程序来实现这个功能:
```c
#include <stdio.h>
#include <ctype.h>
int main() {
char ciphertext[1000];
printf("请输入密文:");
fgets(ciphertext, 1000, stdin);
for (int i = 0; ciphertext[i] != '\0'; i++) {
if (islower(ciphertext[i])) {
// 转换为大写字母并向后移动3位
printf("%c", toupper((ciphertext[i] - 'a' + 3) % 26 + 'A'));
} else {
// 非字母字符直接输出
printf("%c", ciphertext[i]);
}
}
return 0;
}
```
首先,我们使用 `fgets` 函数从标准输入读入密文。然后遍历密文中的每个字符,如果是小写字母,就将其转换为大写字母并向后移动3位,最后输出明文。如果不是字母字符,则直接输出。
注意,我们使用 `islower` 函数来检查一个字符是否为小写字母,并使用 `toupper` 函数将其转换为大写字母。我们还使用了 ASCII 码表中字母字符的顺序来进行字符的转换,因为字母字符在 ASCII 码表中是按顺序排列的。
请注意,此程序可能无法应对各种不同情况的输入,如输入包含非字母字符或超过1000个字符等。在实际使用中,需要对输入进行更严格的检查和处理。
用C语言写一个加密解密的程序
### 回答1:
好的,以下是用C语言写一个加密解密的程序的基本思路:
加密程序:
1. 定义一个字符串用来存储明文。
2. 通过scanf等函数获取用户输入的明文。
3. 定义一个加密函数,接收一个字符串类型的参数,返回加密后的字符串。
4. 在加密函数中,遍历明文字符串的每个字符,对每个字符进行加密操作,例如将字符的ASCII码值加上一个固定的值(加密密钥)。
5. 将加密后的字符串输出。
解密程序:
1. 定义一个字符串用来存储密文。
2. 通过scanf等函数获取用户输入的密文。
3. 定义一个解密函数,接收一个字符串类型的参数,返回解密后的字符串。
4. 在解密函数中,遍历密文字符串的每个字符,对每个字符进行解密操作,例如将字符的ASCII码值减去之前加上的固定值(加密密钥)。
5. 将解密后的字符串输出。
需要注意的是,在实际编写中,还需要考虑输入输出、加密解密密钥的定义、字符串长度的控制等问题。
### 回答2:
使用C语言编写一个简单的加密解密程序可以通过使用基本的加密算法来实现。
加密程序的实现可以使用凯撒密码这一简单的替换密码算法。凯撒密码通过将每个字母按照字母表中顺序向后或向前移动固定的位数来进行加密。例如,移动位数为3的凯撒密码将"A"加密为"D","B"加密为"E",以此类推。
以下是一个使用凯撒密码进行加密的C程序示例:
```c
#include <stdio.h>
#include <string.h>
// 函数用于加密给定的字符串
void encrypt(char string[], int shift) {
int i = 0;
while (string[i] != '\0') {
if (string[i] >= 'A' && string[i] <= 'Z') {
string[i] = ((string[i] - 'A' + shift) % 26) + 'A';
}
else if (string[i] >= 'a' && string[i] <= 'z') {
string[i] = ((string[i] - 'a' + shift) % 26) + 'a';
}
i++;
}
}
// 函数用于解密给定的字符串
void decrypt(char string[], int shift) {
int i = 0;
while (string[i] != '\0') {
if (string[i] >= 'A' && string[i] <= 'Z') {
string[i] = ((string[i] - 'A' - shift + 26) % 26) + 'A';
}
else if (string[i] >= 'a' && string[i] <= 'z') {
string[i] = ((string[i] - 'a' - shift + 26) % 26) + 'a';
}
i++;
}
}
int main() {
char input[100];
int shift;
printf("请输入要加密的字符串:");
fgets(input, sizeof(input), stdin);
printf("请输入移动的位数:");
scanf("%d", &shift);
encrypt(input, shift);
printf("加密后的字符串为:%s\n", input);
decrypt(input, shift);
printf("解密后的字符串为:%s\n", input);
return 0;
}
```
这个程序通过在输入的字符串上应用凯撒密码进行加密和解密。用户可以输入要加密的字符串以及移动的位数,程序将打印出加密和解密后的结果字符串。
请注意,凯撒密码是一种简单的加密算法,并不适合用于真正的加密和安全目的。这只是一个基本示例,用于演示如何使用C语言编写一个加密解密程序。在实际中,我们应该使用更强大和安全的加密算法。
### 回答3:
C语言是一种通用的编程语言,可以用来编写各种类型的程序,包括加密解密程序。在C语言中,可以使用各种算法和技术来实现加密和解密功能。
例如,我们可以使用简单的替换算法实现一个基本的加密解密程序。该程序将使用一个密钥(例如一个整数),将输入的字符串中的每个字符替换为密钥加上原字符的ASCII码值。加密后的字符串就是密文。要解密字符串,只需将密钥减去密文中每个字符的ASCII码值。
下面是一个使用C语言实现的简单加密解密程序的示例代码:
#include <stdio.h>
void encrypt(char *str, int key) {
int i = 0;
while (str[i]) {
str[i] = str[i] + key;
i++;
}
}
void decrypt(char *str, int key) {
int i = 0;
while (str[i]) {
str[i] = str[i] - key;
i++;
}
}
int main() {
char str[100];
int key;
printf("请输入要加密的字符串:");
scanf("%s", str);
printf("请输入密钥:");
scanf("%d", &key);
// 加密
encrypt(str, key);
printf("加密后的字符串:%s\n", str);
// 解密
decrypt(str, key);
printf("解密后的字符串:%s\n", str);
return 0;
}
这段代码中,我们首先定义了两个函数`encrypt`和`decrypt`,分别用于加密和解密字符串。`encrypt`函数将输入的字符串中的每个字符替换为密钥加上原字符的ASCII码值。`decrypt`函数将密文中的每个字符减去密钥得到原始字符的ASCII码值。然后,我们在`main`函数中读取输入的字符串和密钥,并调用`encrypt`函数进行加密,再调用`decrypt`函数进行解密。最后,将加密和解密后的字符串打印出来。
请注意,这只是一个简单的示例,实际上,加密解密算法非常复杂,需要使用更加安全的算法和技术来确保数据的安全性。