机器翻译 2010年NOIP全国联赛提高组

摘要:
该软件将首先在内存中查找单词的中文含义。假设内存中有M个单元。每次软件在内存中存储一个新单词时,如果当前内存中存储的单词数不超过M?软件将新单词存储在未使用的存储单元中;如果内存中存储了M个单词,软件将清空首次进入内存的单词。假设一篇英语文章有N个单词长。翻译软件需要在外部存储器中搜索词典多少次?记忆中没有单词。

题目描述 Description

小晨的电脑上安装了一个机器翻译软件,他经常用这个软件来翻译英语文章。 这个翻译软件的原理很简单,它只是从头到尾,依次将每个英文单词用对应的中文含义 来替换。对于每个英文单词,软件会先在内存中查找这个单词的中文含义,如果内存中有, 软件就会用它进行翻译;如果内存中没有,软件就会在外存中的词典内查找,查出单词的中 文含义然后翻译,并将这个单词和译义放入内存,以备后续的查找和翻译。 假设内存中有M个单元,每单元能存放一个单词和译义。每当软件将一个新单词存入 内存前,如果当前内存中已存入的单词数不超过M?1,软件会将新单词存入一个未使用的 内存单元;若内存中已存入M个单词,软件会清空最早进入内存的那个单词,腾出单元来, 存放新单词。 假设一篇英语文章的长度为N个单词。给定这篇待译文章,翻译软件需要去外存查找多 少次词典?假设在翻译开始前,内存中没有任何单词。

输入描述 Input Description

输入共2行。每行中两个数之间用一个空格隔开。 第一行为两个正整数M和N,代表内存容量和文章的长度。 第二行为N个非负整数,按照文章的顺序,每个数(大小不超过1000)代表一个英文 单词。文章中两个单词是同一个单词,当且仅当它们对应的非负整数相同。

输出描述 Output Description

输出共1行,包含一个整数,为软件需要查词典的次数。

样例输入 Sample Input

3 7

1 2 1 5 4 4 1

样例输出 Sample Output

5

数据范围及提示 Data Size & Hint

【输入输出样例1说明】 整个查字典过程如下:每行表示一个单词的翻译,冒号前为本次翻译后的内存状况: 空:内存初始状态为空。 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次词典。

【数据范围】 对于10%的数据有M=1,N≤5。 对于100%的数据有0≤100,0≤1000。

代碼實現:

机器翻译 2010年NOIP全国联赛提高组第1张机器翻译 2010年NOIP全国联赛提高组第2张
 1 #include<cstdio>
 2 int n,m,a,b,c,ans,s[3000];
 3 bool v[3000];
 4 int main(){
 5 scanf("%d%d",&n,&m);
 6 for(int i=1;i<=m;i++){
 7 scanf("%d",&a);
 8 if(v[a]) continue;
 9 if(!v[a]){
10 if(s[0]==n){v[s[++c]]=0;s[c]=a;v[a]=1;if(c==n) c=0;}
11 else{v[a]=1;s[++s[0]]=a;}
12 ++ans;
13 }
14 }
15 printf("%d
",ans);
16 return 0;
17 }
View Code

因為是數字,所以比較簡單。(其實字符的話,也可以用map)

免责声明:文章转载自《机器翻译 2010年NOIP全国联赛提高组》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇DOCKER 从入门到放弃(五)android之屏幕方向切换下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

flask_jwt_extended 4.0学习

1.前言       在学习flask_jwt_extended插件的时候遇到许多问题,究其原因是因为版本问题,4.0以后的版本在语法上做了许多优化,而我是参考较低版本的flask_jwt_extended学习的,一开始不明白出问题的原因,所以参考了许许多多博友的思路和写法,发现并没有问题,后来想到去看官方的文档,发现了原因所在,以下是4.0版本的api变...

TortoiseGit安装、配置(Git 小乌龟安装)

1 TortoiseGit简介 tortoiseGit是一个开放的git版本控制系统的源客户端,支持Winxp/vista/win7.该软件功能和git一样 不同的是:git是命令行操作模式,tortoiseGit界面化操作模式,不用记git相关命令就可以直接操作,读者可根据自己情况选择安装 2 TortoiseGit下载 官方网址: https://to...

iOS 开发中常见的错误日志处理

Outline如何获得crash日志如何解析crash日志如何分析crash日志     1. iOS策略相关     2. 常见错误标识     3. 代码bug一、如何获得crash日志当一个iOS应用程序崩溃时,系统会创建一份crash日志保存在设备上。这份crash日志记录着应用程序崩溃时的信息,通常包含着每个执行线程的栈调用信息(低内存闪退日志例...

mac的一些基本设置(分享篇)

原文链接:http://www.h5con.cn/macdao/ocds-guide-to-setting-up-mac/blob/master/README.md 原文链接:https://juejin.im/entry/58ca60d461ff4b006018aa2f Awesome Mac:https://github.com/jaywcjlove/...

uni-app微信相关开发问题记录:微信分享报错"包名不对,请检查包名是否与开放平台填写一致"、Android微信支付只能调起一次的问题、App微信登录与公众号微信登录的unionid不一致

1、微信分享报错“微信:包名不对,请检查包名是否与开放平台填写一致”   具体原因及分析见这篇博客:uniapp微信APP支付踩坑指南:报错errMsg: "requestPayment:fail errors" 2、Android微信支付只能调起一次的问题   Android微信支付只能调起一次,之后就再不成功;有博客说卸载微信重装之后,就能成功,发现...

系统接口权限设计

  一、     前言 随着时代发展和技术的进步,系统也在不断发展和完善,从原有的单一的企业开发使用,到现在的跨平台、多系统、多用户的集成对接开发模式。系统的发展也是非常迅速的,很多设计和对接模式也需要不断的改仅和升级。现在的一个系统往往不单单是某一个团队开发、使用,而是多个团队同时开发不同的模块,以及现在的系统往往是平台化的,一些第三方在使用对接的时候,...