今天学了凯撒密码(单表密码),写个明密文对偶表来看看

本文介绍了使用C语言实现的一种简单字母移位加密算法。通过输入移位数,程序能够生成新的字母表,并对字符串进行加密处理。支持大小写字母加密,展示了完整的代码示例及运行效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

#include<stdio.h>

void main()

{

char a[26]={'a','b','c','d','e','f','g','h', 'i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'},b[26];

int i,j,k;

clrscr();

printf("Please input the No. you want to move(0<=j<=25):/t");

scanf("%d",&j);

for(i=0;i<=25;i++)

{

k=(i+j)%26;

b[i]=a[k];

}

for(i=0;i<=25;i++)

{

printf("%c ",a[i]);

}

printf("/n");

for(i=0;i<=25;i++)

{

printf("%c ",b[i]);

}

getch();

}

原理其实很简单,就是字母表中各个元素移位,就这些。

 

顺便写上加密的代码,还不能对句子进行加密,只能单词,但是支持大小写,同样的大写加密规律同小写的是一样的,同样移位。

 

#include<stdio.h>

#include<ctype.h>

void main()

{

char a[26]={'a','b','c','d','e','f','g','h', 'i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'},b[26],*c,d[26];

int i,j,k;

clrscr();

printf("Please input the No. you want to move(0<=j<=25):/t");

scanf("%d",&j);

for(i=0;i<=25;i++)

{

k=(i+j)%26;

b[i]=a[k];

}

for(i=0;i<=26;i++)

{

d[i]=b[i]-32;

}

for(i=0;i<=25;i++)

{

printf("%c ",a[i]);

}

printf("/n");

for(i=0;i<=25;i++)

{

printf("%c ",b[i]);

}

printf("/nPlease input the String you want to Encrypt:/t");

scanf("%s",c);

for(;*c!='/0';c++)

{

if(isalpha(*c)){

if(islower(*c))

*c=b[*c-97];

else  *c=d[*c-65];

}

}

printf("The Encrypted Sting is:/t%s");

getch();

}

下面实验截图:

每天进步一点点~~

 

截图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值