密码学实验1完整版.doc

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
PAGE 报告创建时间:2013.11.25 《现代密码学及其应用》实验报告 年级、专业、班级 2011级计科5班 姓名 杨朝慧 实验题目 Arnold变换 实验时间 2013.11.15 实验地点 A1410 实验成绩 实验性质 □验证性 □设计性 □综合性 教师评价: □算法/实验过程正确; □源程序/实验内容提交 □程序结构/实验步骤合理; □实验结果正确; □语法、语义正确; □报告规范; 其他: 评价教师签名: 一、实验目的 通过编程实现Arnold变换,加深对图像置乱的基本方法,并了解Arnold变换的周期性。 二、实验项目内容 自己创建明文信息(需正方形矩阵形式),并选择一个密钥,即迭代次数,编写Arnold变换实现程序,实现置乱和回复的操作; 三、实验过程或算法(源程序) 程序功能说明: 根据用户输入的行列数ROW_COL,程序随机生成一个矩阵[ROW_COL,ROW_COL],同时每个元素的值在[0, ROW_COL,ROW_COL]之间随机生成。程序第一步可以选择的操作有:置乱、退出,之后可以选择的操作有:置乱、回复、退出。当选择置乱操作时,程序会要求用户输入迭代次数,并根据这个迭代次数算出相对的置乱矩阵;当选择回复操作时,程序会给出这个矩阵的Arnold变换周期数以及当前的这个矩阵回复到原始矩阵需要的迭代次数;当选择退出操作时,程序将会退出。 源程序展示: #includeiostream #includetime.h using namespace std; void zhiLuan(int** I,int ROW_COL)//置乱 { int** I1=new int*[ROW_COL]; for(int i=0;iROW_COL;i++) I1[i]=new int[ROW_COL]; for(int i=0;iROW_COL;i++) for(int j=0;jROW_COL;j++) I1[i][j]=0; int N=0; cout请输入迭代次数: ; cinN; for(int k=0;kN;k++) { for(int i=0;iROW_COL;i++) for(int j=0;jROW_COL;j++) { int x=(i*1+j*1)%ROW_COL; int y=(i*1+j*2)%ROW_COL; I1[x][y]=I[i][j]; } for(int i=0;iROW_COL;i++) for(int j=0;jROW_COL;j++) I[i][j]=I1[i][j]; } cout置乱后的矩阵为:endl; for(int i=0;iROW_COL;i++) { for(int j=0;jROW_COL;j++) coutI[i][j]\t; coutendl; } for (int i=0;iROW_COL;i++)//清除 delete[] I1[i]; delete[] I1; } void getT(int** I,int ROW_COL)//得到周期 { int** BeiI=new int*[ROW_COL];//备份比较 int** I1=new int*[ROW_COL]; for(int i=0;iROW_COL;i++) { BeiI[i]=new int[ROW_COL]; I1[i]=new int[ROW_COL]; } for(int i=0;iROW_COL;i++) for(int j=0;jROW_COL;j++) { BeiI[i][j]=I[i][j]; I1[i][j]=0; } int N=1; for(int k=0;;k++) { for(int i=0;iROW_COL;i++) for(int j=0;jROW_COL;j++) { int x=(i*1+j*1)%ROW_COL; int y=(i*1+j*2)%ROW_COL; I1[x][y]=I[i][j]; } for(int i=0;iROW_COL;i++) for(int j=0;jROW_COL;j++) I[i][j]=I1[i][j]; bool isEqual=true; for(int i=0;iROW_COL;i++) {

您可能关注的文档

文档评论(0)

180****2140 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档