凯撒密码
2021/12/20 6:22:04
本文主要是介绍凯撒密码,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
为了防止信息被别人轻易窃取,需要把电码明文通过加密方式变换成为密文。输入一个以回车符为结束标志的字符串(少于80个字符),再输入一个整数offset,用凯撒密码将其加密后输出。恺撒密码是一种简单的替换加密技术,将明文中的所有字母都在字母表上偏移offset位后被替换成密文,当offset大于零时,表示向后偏移;当offset小于零时,表示向前偏移。
输入格式:
输入第一行给出一个以回车结束的非空字符串(少于80个字符);第二行输入一个整数offset。
输出格式:
输出加密后的结果字符串。
输入样例1:
Hello Hangzhou 2
结尾无空行
输出样例1:
Jgnnq Jcpibjqw
结尾无空行
输入样例2:
a=x+y -1
结尾无空行
输出样例2:
z=w+x
代码:
#include<stdio.h> int main() { int i,j,n; char s[81]; gets(s); scanf("%d",&n); n%=26; for(i=0;s[i]!='\0';i++) { if(s[i]>='a'&&s[i]<='z') { if(n>=0) s[i]=((s[i]-'a')+n)%26+'a'; else s[i]=((s[i]-'a')+n+26)%26+'a'; } else if(s[i]>='A'&&s[i]<='Z') { if(n>=0) s[i]=((s[i]-'A')+n)%26+'A'; else s[i]=((s[i]-'A')+n+26)%26+'A'; } } for(j=0;j<i;j++) printf("%c",s[j]); return 0; }
这篇关于凯撒密码的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-01基于Python+Vue开发的医院门诊预约挂号系统
- 2024-10-01基于Python+Vue开发的旅游景区管理系统
- 2024-10-01RestfulAPI入门指南:打造简单易懂的API接口
- 2024-10-01初学者指南:了解和使用Server Action
- 2024-10-01Server Component入门指南:搭建与配置详解
- 2024-10-01React 中使用 useRequest 实现数据请求
- 2024-10-01使用 golang 将ETH账户的资产平均分散到其他账户
- 2024-10-01JWT用户校验课程:从入门到实践
- 2024-10-01Server Component课程入门指南
- 2024-09-30Dnd-Kit学习:新手快速入门指南