恺撒密码问题 为使电文保密,往往按其规律将其转换成密码,收报人再按约定的规律将其译回原文。例如:将字母A转变成字母E, a变成e, B变成F, b变成f, 即变成其后的第四个字母,W变成A,X变成B,Y变成C,Z变成D……字母按上述规律转换,非字母字符不变。 请编写函数void fun (char *s),将电文按以上规律转换为密码。在主函数中完成字符串的输入及输出。 如s字符串"thank you" 经过fun(s)函数调用后,内容改为"xlero csy"
时间: 2024-02-01 14:13:56 浏览: 26
下面是实现恺撒密码转换的代码:
```c
#include <stdio.h>
void fun(char *s) {
while (*s != '\0') {
if (*s >= 'A' && *s <= 'Z') { // 大写字母
*s = (*s - 'A' + 4) % 26 + 'A'; // 转换成密码
} else if (*s >= 'a' && *s <= 'z') { // 小写字母
*s = (*s - 'a' + 4) % 26 + 'a'; // 转换成密码
} else { // 非字母字符不变
*s = *s;
}
s++; // 指向下一个字符
}
}
int main() {
char s[100];
printf("请输入电文:");
gets(s); // 输入电文
fun(s); // 转换成密码
printf("密码为:%s\n", s); // 输出密码
return 0;
}
```
输入示例:
```
请输入电文:thank you
```
输出示例:
```
密码为:xlero csy
```
相关问题
恺撒密码 python
恺撒密码是一种简单的替换密码,它通过将字母按照一定的位移量进行替换来加密文本。在Python中,你可以使用以下代码来实现恺撒密码的加密和解密:
```python
def caesar_cipher(text, shift):
encrypted_text = ""
for char in text:
if char.isalpha():
ascii_offset = ord('A') if char.isupper() else ord('a')
encrypted_char = chr((ord(char) - ascii_offset + shift) % 26 + ascii_offset)
encrypted_text += encrypted_char
else:
encrypted_text += char
return encrypted_text
# 加密示例
plaintext = "Hello, World!"
shift_amount = 3
encrypted_text = caesar_cipher(plaintext, shift_amount)
print("加密后的文本:", encrypted_text)
# 解密示例
decrypted_text = caesar_cipher(encrypted_text, -shift_amount)
print("解密后的文本:", decrypted_text)
```
这段代码定义了一个 `caesar_cipher` 函数,它接受两个参数:待加密/解密的文本 `text` 和位移量 `shift`。在加密过程中,字母会按照位移量进行替换,非字母字符保持不变。解密过程与加密过程相反,通过将位移量取反来恢复原始文本。
以上代码中的例子使用了一个位移量为3的恺撒密码进行加密和解密。你可以根据自己的需求修改位移量和待加密/解密的文本。
恺撒密码python
恺撒密码是一种古老的加密算法,它采用了替换方法对信息中的每一个英文字符循环替换为字母表序列中该字符后面的第三个字符。在Python中,可以通过手写代码实现恺撒密码的加密和解密。加密方法是将输入字符串中的每个字符循环替换为字母表序列中该字符后面的第三个字符,而解密方法则是将加密后的字符串中的每个字符循环替换为字母表序列中该字符前面的第三个字符。在编写程序时,需要注意对空格和特殊符号的处理。