凯撒凯撒密码实验.doc

凯撒密码  时间:2021-01-24  阅读:()

凯撒密码实验

一、实验目的

通过实验熟练掌握凯撒密码算法学会凯撒密码算法程序设计。 二、实验环境

软件工具:Visual C++ 6.0

操作系统:windows xp

三、实验思想

在密码学中存在着各种各样的置换方式但所有不同的置换方式都包含2个相同的元素。密钥和协议(算法) 。凯撒密码的密钥是3算法是将普通字母表中的字母用密钥对应的字母替换。置换加密的优点就在于它易于实施却难于破解.发送方和接收方很容易事先商量好一个密钥然后通过密钥从明文中生成密文 即是敌人若获取密文通过密文直接猜测其代表的意义在实践中是不可能的。凯撒密码的加密算法极其简单。其加密过程如下:

在这里我们做此约定:明文记为m密文记为c加密变换记为E(k1,m) (其中k1为密钥) 解密变换记为D(k2,m) (k2为解密密钥) (在这里不妨假设k1=k2,记为k) 。凯撒密码的加密过程可记为如下一个变换:c?m+k mod n (其中n为基本字符个数) 同样解密过程可表示为:m?c+k mod n (其中n为基本字符个数) 四、实验数据(源代码)

#include <stdio.h>

#include <stdlib.h>

#include <string.h>void table(char *keyword) //筛选密钥(去重复去空格)

{

int i, j,k;for(i=0;*(keyword+i) !=' \0' ; i++)

{for(j=i ;*(keyword+j) !=' \0' ;j++)

{if(i !=j)if(*(keyword+i)==*(keyword+j) | |*(keyword+j)==' ' ){for(k=j;*(keyword+k) !=' \0' ;k++)

*(keyword+k)=*(keyword+k+1) ;j--;

}

}

}

}void newTab(char *keyword) //生成密钥表

{char ch;int i ;int t;for(t=0;*(keyword+t) !=' \0' ;t++) ;for(ch='a' ;ch<=' z' ;ch++)

{for(i=0;*(keyword+i) !=ch; i++)

{if(*(keyword+i)==' \0' )

{

*(keyword+t)=ch;t++;break;

}

}

}

*(keyword+t)=' \0' ;

}char *Ciphertext(char *keyword,char *Plaintext) //按密码表加密{char ch;int i, j;for(i=0;*(Plaintext+i) !=' \0' ; i++)

{for(ch='a' , j=0;ch<=' z' ;ch++, j++)

{if(*(Plaintext+i)==ch)

{

*(Plaintext+i)=*(keyword+j) ;break;

}

}

}return Plaintext;

}char *Decrypt(char *keyword,char *Plaintext) //解密{char ch;int i, j;for(i=0;*(Plaintext+i) !=' \0' ; i++)

{for(ch='a' , j=0;*(keyword+j) !=' \0' ;ch++, j++)

{if(*(Plaintext+i)==*(keyword+j) )

{

*(Plaintext+i)=ch;break;

}

}

}return Plaintext;

}void main()

{char *keyword,*Plaintext,*tmp=NULL;keyword=(char*)malloc(sizeof(char) ) ;

Plaintext=(char*)malloc(sizeof(char) ) ;

printf("Input key word:") ; //输入欲用密钥gets(keyword) ;printf("Input Plaintext:") ; //输入要转换的明文gets(Plaintext) ;table(keyword) ; //去空格去重复newTab(keyword) ; //生成密码表tmp=Ciphertext(keyword,Plaintext) ; //对应着密码表生成密文puts(tmp) ; //输出密文puts(Decrypt(keyword, tmp) ) ; //解密输出

}

五、实验心得

通过本次实验将凯撒密码算法的理论应用到实践中来利用C++编程实现了凯撒密码算法的加密过程将理论与实践结合起来加深了课本上凯撒密码算法理论的理解。

欢迎您阅读该资料希望该资料能给您的学习和生活带来帮助如果您还了解更多的相关知识也欢迎您分享出来让我们大家能共同进步、共同成长。

欢迎使用“凯撒密码实验”使用该文档doc格式如大家有其它疑问或者新的见解欢迎大家互相交流、互相进步。

妮妮云香港CTG云服务器1核 1G 3M19元/月

香港ctg云服务器香港ctg云服务器官网链接 点击进入妮妮云官网优惠活动 香港CTG云服务器地区CPU内存硬盘带宽IP价格购买地址香港1核1G20G3M5个19元/月点击购买香港2核2G30G5M10个40元/月点击购买香港2核2G40G5M20个450元/月点击购买香港4核4G50G6M30个80元/月点击购买香...

香港E3-1230v2 16GB 30M 326元/月 数脉科技

官方网站:https://www.shuhost.com/公司名:LucidaCloud Limited尊敬的新老客户:艰难的2021年即将结束,年终辞旧迎新之际,我们准备了持续优惠、及首月优惠,为中小企业及个人客户降低IT业务成本。我们将持续努力提供给客户更好的品质与服务,在新的一年期待与您有美好的合作。# 下列价钱首月八折优惠码: 20211280OFF (每客户限用1次) * 自助购买可复制...

pacificrack:2021年七夕VPS特别促销,$13.14/年,2G内存/2核/60gSSD/1T流量,支持Windows

pacificrack官方在搞2021年七夕促销,两款便宜vps给的配置都是挺不错的,依旧是接入1Gbps带宽,KVM虚拟、纯SSD raid10阵列,支持包括Linux、Windows 7、10、server2003、2008、2012、2016、2019在内多种操作系统。本次促销的VPS请特别注意限制条件,见本文末尾!官方网站:https://pacificrack.com支持PayPal、支...

凯撒密码为你推荐
金士顿内存卡价格金士顿16G和32G内存卡 价格燃气热水器和电热水器哪个好燃气热水器和电热水器的区别是什么,哪个比较好?免费阅读小说app哪个好什么小说软件好用又免费手机浏览器哪个好手机上的浏览器哪个比较好?传奇类手游哪个好传奇手游哪个好玩免费少儿英语哪个好少儿英语哪个好少儿英语哪个好少儿英语,那个好一些?音乐播放器哪个好音乐播放器哪个好用无纺布和熔喷布口罩哪个好口罩选择什么样的面料好杰士邦和杜蕾斯哪个好杰士邦的超薄款跟杜蕾斯的超薄款,哪个舒服点?
100m网站空间 顶级域名 新网域名解析 80vps pw域名 10t等于多少g 免费ftp空间 lamp配置 国外在线代理 北京双线机房 新家坡 可外链网盘 1g内存 linux服务器维护 100mbps 上海服务器 优酷黄金会员账号共享 彩虹云 域名与空间 1元域名 更多