🍀作者简介:被吉师散养、喜欢前端、学过后端、练过CTF、玩过DOS、不喜欢java的不知名学生。
🍁个人主页:红中
🫒每日emo:等我把脸皮磨厚
🍂专栏地址:网安专栏
今天周日,本来想睡个好觉,突然想起系主任临时加了节早八。
让我死吧。。。
设个闹钟,早上把会议挂上,签个到,直接睡大觉。
十点多醒了,发现讲的凯撒密码和维吉尼亚密码
作为一个前几天刚学完des加密的人,这俩怎么能难住我,现挂直接出文章
看了眼,发现这个凯撒密码挺简单的
在密码学中,恺撒密码(英语:Caesar cipher),或称恺撒加密、恺撒变换、变换加密,是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。当年恺撒曾用此方法与其将军们进行联系。---------------------------------------引自百度百科
要是我在那个年代出生,凯撒密码?给你打穿
还是老三样
凯撒密码需要两个东西
简单来说就是根据ASCII表推位数
好比对A进行加密,后移位数是7
加密后就得到H
没了,就这么简单
那我就简单叭叭两句,凯撒密码只对字母有效,并且区分大小写。
#include int main(){char plaintext[100],ciphertext[100];char m;int i,j=0;printf("请输入明文:\n");gets(plaintext);printf("请输入加密位数:\n");scanf("%d", &i);for(j = 0; plaintext[j] != '\0'; j++){m = plaintext[j];if(m <= 'Z' && m >='A')//往后移ciphertext[j] = (m - 'A' + i) % 26 + 'A';else if(m <= 'z' && m >='a')ciphertext[j] = (m - 'a' + i) % 26 + 'a';else ciphertext[j] = m;}ciphertext[j] = '\0';//添加结束符printf("加密后的密文如下:\n");for(j = 0; ciphertext[j] != '\0'; j++)printf("%c", ciphertext[j]);printf("\n");}
这个密码呢,其实也挺简单的,就是在凯撒密码的基础上加了个密钥
第一行就是密钥
第一列是明文
好比对m进行加密,密钥是z,
密文为L
所以这玩意和凯撒有啥关系。。
想不明白
#include
#include void encrypt(char *text, char *result, char *k)
{int i,j=0,z=0;for(i=0;i='a' && text[i] <= 'z') //小写字母result[z]=(text[i]-'a'+k[j]-'a')%26 +'A';else //大写字母result[z]=(text[i]-'A'+k[j]-'a')%26 +'A';j++;if(j>=strlen(k)) j=0;//以密钥长度为一个周期循环z++;}
}int main()
{char text[99]="";char result[99]="";char k[99]="";printf("请输入一段小写英文字母:");//默认输入为一段连续英文字母串scanf("%s",text);printf("请输入密钥:");//密钥默认小写scanf("%s",k);encrypt(text,result,k);printf("密文为:%s\n",result);}
我得做核酸去了,溜了溜了
上一篇:Redis