BZOJ4837:[Lydsy1704月赛]LRU算法(双指针&模拟)
Description
Input
Output
对于每组测试数据,输出一行一个非负整数,表示这组数据的答案。
Sample Input
5 10
0 1 1 5
5 10
0 1 1 10
Sample Output
1135
思路:加入X,如果X不存在队列,当队列里小于N个,直接加到队尾;否则删去队首删去队尾。 如果X存在队里,那么移到队尾。 我们发现用队列不方便模拟,因为无法删去中间的数,而set来操作又会超时。 因为我们维护的是一个长度为N的窗口,可以用双指针来模拟。 维护一个队列q,如果q[i]=-1,说明位置i已经被删去。同时维护一个pos数组保保存其在队列的位置。 最后用一个队首head来维护现在删到了哪里。
#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int maxn=;
ll a[maxn],A,B,P; int q[maxn],pos[maxn],cnt,head,num;
unsigned long long ans,res;
int main()
{
int T,N,Q;
scanf("%d",&T);
while(T--){
cnt=; ans=; res=; head=; num=;
scanf("%d%d",&N,&Q);
scanf("%lld%lld%lld%lld",&a[],&A,&B,&P);
for(int i=;i<=Q;i++) a[i]=(A*a[i-]+B)%P;
for(int i=;i<=Q;i++) pos[a[i]]=-;
for(int i=;i<=Q;i++){
if(pos[a[i]]==-){
if(num<N) {
num++;
pos[a[i]]=++cnt, q[cnt]=a[i],res+=a[i];
}
else {
while(q[head]==-) head++;
pos[q[head]]=-,res-=q[head],q[head]=-;
pos[a[i]]=++cnt,q[cnt]=a[i],res+=a[i];
}
}
else {
q[pos[a[i]]]=-,pos[a[i]]=++cnt,q[cnt]=a[i];
}
ans+=res*i;
}
cout<<ans<<endl;
}
return ;
}
BZOJ4837:[Lydsy1704月赛]LRU算法(双指针&模拟)的更多相关文章
- 【BZOJ4837】LRU算法 [模拟]
LRU算法 Time Limit: 6 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description 小Q同学在学习操作系统中内存管理的 ...
- 使用java.util.LinkedList模拟实现内存页面置换算法--LRU算法
一,LRU算法介绍 LRU是内存分配中“离散分配方式”之分页存储管理方式中用到的一个算法.每个进程都有自己的页表,进程只将自己的一部分页面加载到内存的物理块中,当进程在运行过程中,发现某页面不在物理内 ...
- python模拟页面调度LRU算法
所谓LRU算法,是指在发生缺页并且没有空闲主存块时,把最近最少使用的页面换出主存块,腾出地方来调入新页面. 问题描述:一进程获得n个主存块的使用权,对于给定的进程访问页面次序,问当采用LRU算法时,输 ...
- FIFO调度算法和LRU算法
一.理论 FIFO:先进先出调度算法 LRU:最近最久未使用调度算法 两者都是缓存调度算法,经常用作内存的页面置换算法. 打一个比方,帮助你理解.你有很多的书,比如说10000本.由于你的书实在太多了 ...
- 【Redis 设置Redis使用LRU算法】
转自:http://ifeve.com/redis-lru/ 本文将介绍Redis在生产环境中使用的Redis的LRU策略,以及自己动手实现的LRU算法(php) 1.设置Redis使用LRU算法 L ...
- 关于LRU算法(转载)
原文地址: http://flychao88.iteye.com/blog/1977653 http://blog.csdn.net/cjfeii/article/details/47259519 ...
- Android图片缓存之Lru算法
前言: 上篇我们总结了Bitmap的处理,同时对比了各种处理的效率以及对内存占用大小.我们得知一个应用如果使用大量图片就会导致OOM(out of memory),那该如何处理才能近可能的降低oom发 ...
- 缓存淘汰算法--LRU算法
1. LRU1.1. 原理 LRU(Least recently used,最近最少使用)算法根据数据的历史访问记录来进行淘汰数据,其核心思想是"如果数据最近被访问过,那么将来被访问的几率也 ...
- 借助LinkedHashMap实现基于LRU算法缓存
一.LRU算法介绍 LRU(Least Recently Used)最近最少使用算法,是用在操作系统中的页面置换算法,因为内存空间是有限的,不可能把所有东西都放进来,所以就必须要有所取舍,我们应该把什 ...
随机推荐
- RabbitMQ入门(5)——主题(Topic)
前面我们介绍了通过使用direct exchage,改善了fanout exchange只能进行虚拟广播的方式.尽管如此,直接交换也有自身的局限,它不能基于多个条件路由. 在我们的日志系统中,也许我们 ...
- spring boot2.1读取 apollo 配置中心2
第二篇:创建spring boot2.1项目 引用apollo的java客户端jar包 <dependency> <groupId>com.ctrip.framework.ap ...
- JavaScript对象、JSON对象、JSON字符串的区别
一.首先看下什么是JSON JSON:JavaScript Object Natation,JavaScript对象的表现形式,已经发展成一种轻量级的数据交换格式. JavaScript对象的表现形式 ...
- Centos7.2 FastDFS_V5.05 集群的安装与配置1
环境: Centos 7.2/64位 两台服务器 都为tracker 和 storage 10.100.0.1 storage tracker10.100.0.2 storage tracker ...
- String类的subString(i)方法(基于jdk 1.9)
只有一个参数的: String str = new String("ABCD"); System.out.println("str="+str.substrin ...
- dom&bom的起源,方法,内容,应用
Document Object Model的历史可以追溯至1990年代后期微软与Netscape的"浏览器大战"(browser wars),双方为了在JavaScript与JSc ...
- 《深入理解mybatis原理2》 Mybatis初始化机制详解
<深入理解mybatis原理> Mybatis初始化机制详解 对于任何框架而言,在使用前都要进行一系列的初始化,MyBatis也不例外.本章将通过以下几点详细介绍MyBatis的初始化过程 ...
- edm 邮件制作指南
格式编码 1.页面宽度请设定在 600px 到 800px 以内,长度 1024px 以内. 2.html 编码请使用 utf-8. 3.html 代码在 15KB 以内.(各个邮箱的收件标准不一样, ...
- Ansible 小手册系列 六(Patterns 匹配模式)
Patterns 是定义Ansible要管理的主机.但是在playbook中它指的是对应主机应用特定的配置或IT流程. 命令格式 命令行 ansible <host-pattern> [o ...
- 012PHP基础知识——运算符(五)
<?php /** * 运算符的短路: * && 逻辑与 || 逻辑或 存在短路: */ /* $a = 1; $a==1 ||$c=100; //逻辑或:第一个表达式返回tru ...