首页 > 其他分享 >004. [NOIP2017 提高组] 机器翻译(洛谷P1540)

004. [NOIP2017 提高组] 机器翻译(洛谷P1540)

时间:2024-12-27 23:42:44浏览次数:5  
标签:NOIP2017 翻译 洛谷 机器翻译 单词 leq 查找 内存 软件

004. [NOIP2017 提高组] 机器翻译(洛谷P1540)

题目背景

NOIP2010 提高组 T1

题目描述

小晨的电脑上安装了一个机器翻译软件,他经常用这个软件来翻译英语文章。

这个翻译软件的原理很简单,它只是从头到尾,依次将每个英文单词用对应的中文含义来替换。对于每个英文单词,软件会先在内存中查找这个单词的中文含义,如果内存中有,软件就会用它进行翻译;如果内存中没有,软件就会在外存中的词典内查找,查出单词的中文含义然后翻译,并将这个单词和译义放入内存,以备后续的查找和翻译。

假设内存中有 \(M\) 个单元,每单元能存放一个单词和译义。每当软件将一个新单词存入内存前,如果当前内存中已存入的单词数不超过 \(M-1\),软件会将新单词存入一个未使用的内存单元;若内存中已存入 \(M\) 个单词,软件会清空最早进入内存的那个单词,腾出单元来,存放新单词。

假设一篇英语文章的长度为 \(N\) 个单词。给定这篇待译文章,翻译软件需要去外存查找多少次词典?假设在翻译开始前,内存中没有任何单词。

输入格式

共 \(2\) 行。每行中两个数之间用一个空格隔开。

第一行为两个正整数 \(M,N\),代表内存容量和文章的长度。

第二行为 \(N\) 个非负整数,按照文章的顺序,每个数(大小不超过 \(1000\))代表一个英文单词。文章中两个单词是同一个单词,当且仅当它们对应的非负整数相同。

输出格式

一个整数,为软件需要查词典的次数。

样例 #1

样例输入 #1

3 7
1 2 1 5 4 4 1

样例输出 #1

5

提示

样例解释

整个查字典过程如下:每行表示一个单词的翻译,冒号前为本次翻译后的内存状况:

  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 \leq 5\);
  • 对于 \(100\%\) 的数据有 \(1 \leq M \leq 100\),\(1 \leq N \leq 1000\)。

题解

典型的模拟题

看到“清空最早进入内存的那个单词”这个语句,我就想到了先进先出的队列。(为什么我没用手动队列?因为我懒

于是一切就变得很容易了。

我开了一个队列 q 模拟内存情况,数组 inq 来判断每个单词是否在内存中,每次需要去外存查找就ans++。具体细节见注释。

AC代码:

#include<iostream>
#include<queue>

using namespace std;

queue<int> q;//队列模拟内存情况
int m,n,ans;
bool inq[1010];//判断单词是否在内存中

int main()
{
	cin>>m>>n;
	for(int i=1;i<=n;i++)
	{
		int x;
		cin>>x;
		if(inq[x])continue;//能够在内存中查找就跳过
		else
		{
        	//如果内存满了,最早进入内存的那个单词出列
			if(q.size()>=m)
			{
				inq[q.front()]=false;
				q.pop();
			}
            //把外存的结果加入内存以便下次查找
			q.push(x);
			inq[x]=true;
			ans++;
		}
	}
	cout<<ans;
	return 0;
}

标签:NOIP2017,翻译,洛谷,机器翻译,单词,leq,查找,内存,软件
From: https://www.cnblogs.com/zyihan-crz/p/18636906

相关文章

  • 005. [NOIP2017 提高组] 时间复杂度(洛谷P3952)
    005.[NOIP2017提高组]时间复杂度(洛谷P3952)题目背景NOIP2017提高组D1T2题目描述小明正在学习一种新的编程语言A++,刚学会循环语句的他激动地写了好多程序并给出了他自己算出的时间复杂度,可他的编程老师实在不想一个一个检查小明的程序,于是你的机会来啦!下面请你编写程序......
  • gesp(二级)(15)洛谷:B4036:[GESP202409 二级] 数位之和
    gesp(二级)(15)洛谷:B4036:[GESP202409二级]数位之和题目描述小杨有nnn个正整数,他认为一个正整数是美丽数字当且仅当该正整数每一位数字的总和是......
  • gesp(二级)(16)洛谷:B4037:[GESP202409 二级] 小杨的 N 字矩阵
    gesp(二级)(16)洛谷:B4037:[GESP202409二级]小杨的N字矩阵题目描述小杨想要构造一个m×mm\timesmm×m......
  • 洛谷题单指南-线段树的进阶用法-P3834 【模板】可持久化线段树 2
    原题链接:https://www.luogu.com.cn/problem/P3834题意解读:静态区间第k小问题,可持久化线段树(也称为主席树)模版题。解题思路:一、朴素想法:如何求完整区间[1,n]第k小1、权值线段树设n个数构成序列a,b数组代表a中元素出现的次数,即b数组的构建方式为对每一个a[i]做b[a[i]]++。针对b......
  • 洛谷 P3293 [SCOI2016] 美味
    题目描述一家餐厅有\(n\)道菜,编号\(1,2,\ldots,n\),大家对第\(i\)道菜的评价值为\(a_i\)。有\(m\)位顾客,第\(i\)位顾客的期望值为\(b_i\),而他的偏好值为\(x_i\)。因此,第\(i\)位顾客认为第\(j\)道菜的美味度为\(b_i\oplus(a_j+x_i)\),\(\oplus\)表示异或运......
  • 002. 队列安排(洛谷P1160)
    002.队列安排(洛谷P1160)题目描述一个学校里老师要将班上\(N\)个同学排成一列,同学被编号为\(1\simN\),他采取如下的方法:先将\(1\)号同学安排进队列,这时队列中只有他一个人;\(2\simN\)号同学依次入列,编号为\(i\)的同学入列方式为:老师指定编号为\(i\)的同学站在......
  • 001. 约瑟夫问题(洛谷P1996)
    001.约瑟夫问题(洛谷P1996)题目描述\(n\)个人围成一圈,从第一个人开始报数,数到\(m\)的人出列,再由下一个人重新从\(1\)开始报数,数到\(m\)的人再出圈,依次类推,直到所有的人都出圈,请输出依次出圈人的编号。注意:本题和《深入浅出-基础篇》上例题的表述稍有不同。书上表述是......
  • 线段树1模板 (洛谷p3372)
    关键在于创建一个向上返回的函数up,向下查询的同时将父亲sum和add值传给儿子函数down最后用lazy函数更新sum和add的值先通过build函数是sum数组完成初始化,然后用adds已经quiey函数完成求解,详细注释见代码​#include<iostream>#include<cstdio>usingnamespacestd;intm......
  • 谈谈大语言模型和机器翻译:以及我们如何来应对
    大型语言模型(LLM)已经风靡全球。前排提示,文末有大模型AGI-CSDN独家资料包哦!其中一些模型,例如OpenAI的GPT-4和谷歌的PaLM2,已经在多语言数据集上进行了训练,并且至少在理论上也应该能够很好地完成机器翻译任务。如何充分发挥大型语言模型在机器翻译中的潜力?下面我们来......
  • gesp(三级)(9)洛谷:B3956:[GESP202403 三级] 字母求和
    gesp(三级)(9)洛谷:B3956:[GESP202403三级]字母求和题目描述小杨同学发明了一种新型密码,对于每一个小写英文字母,该小写字母代表了一个正整数,即该字母在字母顺序中的位置,例如字母a代表了正整数1......