- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
FaultNum = 0; for(i = 0; i FN; i++) order[i] = 0; for(i = 0; i PN; i++) { for(j = 0; j FN; j++) { if(pages[i] == order[j]) { for(k = j-1; k = 0; k--) { order[k+1] = order[k]; } order[0] = pages[i]; break; } } if(j = FN) { FaultNum ++; for(k = FN-2; k = 0; k--) { order[k+1] = order[k]; } order[0] = pages[i]; } } printf(缺页中断次数:%d\n, FaultNum); } 运行结果: 请输入物理页面的个数:4 请输入页面序列(-1结束): 1 2 3 4 1 2 5 1 2 3 4 5 -1 缺页中断次数:8 4.4.7 凯撒密码 问题背景: 史上最早的一种加密系统是由Julius Caesar发明的:若需要加密的字母是字母表中的第N个字母,那么就用第(N+K)个字母来代替它,其中K是某个固定的整数(凯撒使用的是K=3)。通常把空格字符看成是第0个字符,即总共有27个字符。例如,若K=1,则消息“ATTACK AT DAWN”就会被加密为“BUUBDLABUAEBXO”。 解密这样的一条消息非常简单,只需尝试K的26种不同取值即可。这个过程需要用到语言知识的帮助,这样才能判断解密出来的文字是否是合理的单词,如果缺乏相应的语言知识,就需要词典的帮助。 问题描述: 读入一部词典和加密后的文字,程序将确定所使用的K值,并显示经过解密后的原始内容。原始内容仅包含字母和空格。 输入:词典不超过100行,每行是一个大写单词,长度不超过20,词典以#结尾。加密后的文字只有一行,长度不超过250。注:词典不一定包含原文所有单词,且无序。 关键问题: 如何确定K值! 问题分析 K=1, 2, 3, … 26,逐一进行测试; 根据K值,对密文进行解密,得到一行文字,即“单词”序列; 将这些“单词”与词典进行比较,统计出有效单词的个数; 选择有效单词数最多的。 算法思路 对密文进行解密,得到“单词”序列; 单词抽取; 在词典中查找特定的单词; 有效单词的统计; 有效单词个数的最大值。 关键技术 密文解密: 逐个字母进行解密。已知K,若加密后的字母序号为N,则解密后的字母序号为: (N-K+27) % 27 如何计算N? 单词抽取: ATTACK AT DAWN #include stdio.h #include string.h void main() { char LexicalItems[100][20], CypherText[250]; char Decrypted[250], Message[250], word[250]; int Index[250], i, j, k; int ItemNum, len, MatchNum, MaxNum, BestK; ItemNum = 0; while(1) { scanf(%s, LexicalItems[ItemNum]); if(!strcmp(LexicalItems[ItemNum], #)) break; ItemNum++; } fflush(stdin); gets(CypherText); len = strlen(CypherText); for(j = 0; j len; j++) { if(CypherText[j] == ) Index[j] = 0; else Index[j] = CypherText[j] - A + 1; }
您可能关注的文档
最近下载
- 2025年全国英语等级考试PETS一级试卷:词汇与语法测试题库.docx VIP
- 2023年广西民族大学219翻译硕士泰语B卷考研真题.pdf VIP
- 汇川INOVANCE MD290系列通用变频器综合手册.PDF VIP
- 2020年广西民族大学219翻译硕士泰语(A卷)考研真题.pdf VIP
- GB-T 2423 2-2001电工电子产品环境试验第2部分:试验方法试验B:高温.docx VIP
- 第二单元《我们的班级》第7课《我是班级值日生》 (教学设计)统编版道德与法治二年级上册.docx VIP
- 实验室安全知识培训-完整版.pptx VIP
- 中华保险公司题目行测.pdf
- 练习十四 课件 人教版六年级数学上册.ppt VIP
- 2018年广西民族大学219翻译硕士泰语考研真题.pdf VIP
文档评论(0)