凯撒凯撒密码实验.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格式如大家有其它疑问或者新的见解欢迎大家互相交流、互相进步。

Hostodo(年付$34.99), 8TB月流量 3个机房可选

Hostodo 算是比较小众的海外主机商,这次九月份开学季有提供促销活动。不过如果我们有熟悉的朋友应该知道,这个服务商家也是比较时间久的,而且商家推进活动比较稳,每个月都有部分活动。目前有提供机房可选斯波坎、拉斯维加斯和迈阿密。从机房的地理位置和实际的速度,中文业务速度应该不是优化直连的,但是有需要海外业务的话一般有人选择。以前一直也持有他们家的年付12美元的机器,后来用不到就取消未续约。第一、开...

RAKsmart:美国圣何塞服务器限量秒杀$30/月起;美国/韩国/日本站群服务器每月189美元起

RAKsmart怎么样?RAKsmart是一家由华人运营的国外主机商,提供的产品包括独立服务器租用和VPS等,可选数据中心包括美国加州圣何塞、洛杉矶、中国香港、韩国、日本、荷兰等国家和地区数据中心(部分自营),支持使用PayPal、支付宝等付款方式,网站可选中文网页,提供中文客服支持。本月商家继续提供每日限量秒杀服务器月付30.62美元起,除了常规服务器外,商家美国/韩国/日本站群服务器、1-10...

搬瓦工最新套餐KVM,CN2线路

搬瓦工在国内非常流行的主机商,以提供低价的vps著称.不过近几年价格逐渐攀升.不过稳定性和速度一向不错.依然深受国内vps爱好者喜爱.新上线的套餐经常卖到断货.支持支付宝,paypal很方便购买和使用.官网网站:https://www.bandwagonhost.com[不能直接访问,已墙]https://www.bwh88.net[有些地区不能直接访问]https://www.bwh81.net...

凯撒密码为你推荐
宝来和朗逸哪个好宝来和朗逸哪个好炒股软件哪个好请问有什么好用的免费股票软件?加速器哪个好英雄联盟有什么加速器好用的?海克斯皮肤哪个好海克斯安妮和摄魂薇恩哪个好 需要多少宝石yy空间登录怎么进入YY音乐空间铁通dns服务器地址嘉兴铁通的DNS服务器地址是多少?360云盘怎么用360云盘如何使用?月抛隐形眼镜隐形眼镜(月抛)、过了一个月还能再用吗?便宜的近义词便宜的近义词电影票在哪买便宜在哪买电影票最便宜
香港主机租用 187邮箱 亚洲大于500m flashfxp怎么用 国内免备案主机 冰山互联 优惠码 长沙服务器 湖南服务器托管 qq数据库下载 免费个人空间申请 godaddy域名证书 有益网络 qq云端 中国电信宽带测速网 免费phpmysql空间 怎么建立邮箱 国外视频网站有哪些 网页提速 太原联通测速 更多