题目信息

题目类型
六级
题目年份
2021
题目题型
编程题
关 键 词
机器翻译

题目题干

2.机器翻译MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

VariantF的电脑上安装了一个机器翻译软件,他经常用这个软件来翻译英语文章。这个翻译软件的原理很简单,它只是从头到尾,依次将每个英文单词用对应的中文含义来替换。对于每个英文单词,软件会先在内存中查找这个单词的中文含义,如果内存中有,软件就会用它进行翻译;如果内存中没有,软件就会在外存中的词典内查找,查出单词的中文含义然后翻译,并将这个单词和译义放入内存,以备后续的查找和翻译。MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

假设内存中有M 个单元,每单元能存放一个单词和译义。每当软件将一个新单词存入内存前,如果当前内存中已存入的单词数不超过M,软件会将新单词存入一个未使用的内存单元;若内存中已存入M 个单词,软件会清空最早进入内存的那个单词,腾出单元来,存放新单词。MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

假设一篇英语文章的长度为N 个单词。给定这篇待译文章,翻译软件需要去外存查找多少次词典?假设在翻译开始前,内存中没有任何单词。MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

时间限制:1000MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

内存限制:262144MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

输入MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

第一行为两个正整数M 和N,代表内存容量和文章的长度。 第二行为N 个非负整数,按照文章的顺序,每个数(大小不超过1000000)代表一个英文单词。文章中两个单词是同一个单词,当且仅当它们对应的非负整数相同。 对于50%的数据,1<=N、M<=1000; 对于100%的数据,1<=N、M<=1000000。MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

输出MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

一个整数,为软件需要查词典的次数。MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

 MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

样例输入MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

3 7 
1 2 1 5 4 4 1

样例输出MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

5

 MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

提示MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

整个查字典过程如下:每行表示一个单词的翻译,冒号前为本次翻译后的内存状况: 空:内存初始状态为空。 1. 1:查找单词1 并调入内存。 2. 1 2:查找单词2 并调入内存。 3. 1 2:在内存中找到单词1。 4. 1 2 5:查找单词5 并调入内存。 5. 2 5 4:查找单词4 并调入内存替代单词1。 6. 2 5 4:在内存中找到单词4。 7. 5 4 1:查找单词1 并调入内存替代单词2。 共计查了5 次词典。MJ0100150满分答卷(100150.com)-青少年编程等级考试及竞赛题库

答案解析

相关题目

3.括号画家 Candela是一名漫画家,她有一个奇特的爱好,就是在纸上画括号。这一天,刚刚起床的Candela画了一排括号序列,其中包含小括号()、中括号[]和大括号{},总长度为N。这排随意绘制
2.机器翻译 VariantF的电脑上安装了一个机器翻译软件,他经常用这个软件来翻译英语文章。这个翻译软件的原理很简单,它只是从头到尾,依次将每个英文单词用对应的中文含义来替换。对于每个英文单词,软
1.生日相同 2.0 在一个有180人的大班级中,存在两个人生日相同的概率非常大,现给出每个学生的名字,出生月日。试找出所有生日相同的学生。 时间限制:1000 内存限制:65536 输入
4.合影效果。 小云和朋友们去爬香山,为美丽的景色所陶醉,想合影留念。如果他们站成一排,男生全部在左(从拍照者的角度),并按照从矮到高的顺序从左到右排,女生全部在右,并按照从高到矮的顺序从左到右排
3.发型糟糕的一天。 农夫John 的N(1 ≤ N ≤ 80,000)只奶牛中,有一些也许正在经历发型糟糕的一天。每只奶牛对自己乱糟糟的发型都有自知之明,农夫John想知道所有奶牛能看到其他奶牛
2.栈的基本操作。 栈是一种重要的数据结构,它具有push k和pop操作。push k是将数字k加入到栈中,pop则是从栈中取一个数出来。栈是后进先出的:把栈也看成横向的一个通道,则push k
1.stack or queue。 栈和队列都是常用的线性结构,它们都提供两个操作: Push:加入一个元素。 Pop:弹出一个元素。 不同的是,栈是”先进后出”,而队列则是”先进先出”。给
4.词典 你旅游到了一个国外的城市。那里的人们说的外国语言你不能理解。不过幸运的是,你有一本词典可以帮助你。 时间限制:3000 内存限制:65536 输入 首先输入一个词典,词典中包含不超过
3.出栈序列统计 栈是常用的一种数据结构,有n个元素在栈顶端一侧等待进栈,栈顶端另一侧是出栈序列。你已经知道栈的操作有两种:push和pop,前者是将一个元素进栈,后者是将栈顶元素弹出。现在要使用这两
2.队列和栈  队列和栈是两种重要的数据结构,它们具有push k和pop操作。push k是将数字k加入到队列或栈中,pop则是从队列和栈取一个数出来。队列和栈的区别在于取数的位置是不同的。 队列

提示声明

  • 免责声明:本站资源均来自网络或者用户投稿,仅供用于学习和交流:如有侵权联系删除!
  • 温馨提示:本文属于积分文章,需要充值获得积分或升级VIP会员,也可在会员中心投稿获取。

猜你喜欢