LRU Algorithm Gym - 102394L (HASH)
LRU Algorithm
\]
题意
给出 \(n\) 个数字和 \(m\) 次查询。
每次询问中,给出 \(L\) 表示 \(LRU\) 中缓存器的大小,再给出 \(L\) 个数字,问对 \(n\) 个数字做大小为 \(L\) 的 \(LRU\) 过程中,会不会有某一时刻,缓存器中的数字序列和给出的 \(L\) 个数字一致。
思路
首先对于 \(LRU\) 算法,当缓存器大小为 \(L\)时,以某个位置 \(pos\) 结束的缓存器中的元素,本质上就是从 \(pos\) 往前的 \(L\) 个第一次出现的不同的数字。所以每次查询我们只要想办法找出以每个位置结束,往前 \(L\) 个不同的数字是什么,然后判断和所查询的序列是否一致,就可以知道是 \(Yes\) 或者是 \(No\) 了。
首先发现 \(n=5000\),那么可以 \(n^2\) 暴力预处理出 \(has[i][j]\),表示从 \(i\) 开始,往前 \(j\) 个不同的数字所构成的 \(hash\) 值,然后只要判断给出的 \(L\) 个数字的 \(hash\) 值是否满足条件就可以了。注意判断一下不满 \(L\) 个元素的情况,那就还要求找到的 \(pos\) 位置以前只存在给出的数字。
/***************************************************************
> File Name : L.cpp
> Author : Jiaaaaaaaqi
> Created Time : Tue 12 Nov 2019 04:58:09 PM CST
***************************************************************/
#include <map>
#include <set>
#include <list>
#include <ctime>
#include <cmath>
#include <stack>
#include <queue>
#include <cfloat>
#include <string>
#include <vector>
#include <cstdio>
#include <bitset>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <unordered_map>
#define lowbit(x) x & (-x)
#define mes(a, b) memset(a, b, sizeof a)
#define fi first
#define se second
#define pb push_back
#define pii pair<int, int>
typedef unsigned long long int ull;
typedef long long int ll;
const int maxn = 5e3 + 10;
const int maxm = 1e5 + 10;
const ll mod = 1e9 + 7;
const ll INF = 1e18 + 100;
const int inf = 0x3f3f3f3f;
const double pi = acos(-1.0);
const double eps = 1e-8;
using namespace std;
int n, m;
int cas, tol, T;
int aa[maxn];
int a[maxn], b[maxn];
int vis[maxn], pre[maxn];
ull has[maxn][maxn], seed = 233;
int main() {
// freopen("in", "r", stdin);
scanf("%d", &T);
while(T--) {
scanf("%d%d", &n, &m);
for(int i=1; i<=n; i++) scanf("%d", &aa[i]);
int len1 = 0, len2 = 0;
for(int i=1; i<=n; i++) {
if(n==0 || aa[i]!=a[len1]) a[++len1] = aa[i];
}
for(int i=1; i<=n; i++) vis[i] = pre[i] = 0;
for(int i=1; i<=n; i++) {
pre[i] = pre[i-1];
if(vis[a[i]] == 0) pre[i]++;
vis[a[i]]++;
}
for(int i=n; i>=1; i--) {
for(int j=1; j<=n; j++) vis[j] = 0;
int cnt = 0;has[i][0] = 0;
for(int j=i; j>=1; j--) {
if(vis[a[j]] == 0) {
cnt++;
has[i][cnt] = has[i][cnt-1] * seed + a[j];
}
vis[a[j]]++;
}
}
while(m--) {
scanf("%d", &len2);
for(int i=1; i<=len2; i++) scanf("%d", &b[i]);
bool flag = 0;
while(len2 && b[len2] == 0) len2--, flag = 1;
if(len2 == 0) {
printf("Yes\n");
continue;
}
ull ans = 0;for(int i=1; i<=len2; i++) ans = ans*seed+b[i];
int pos = 0;
for(int i=1; i<=len1; i++) {
if(has[i][len2] == ans) {
pos = i;
break;
}
}
if(pos && (!flag || (flag && pre[pos]==len2))) printf("Yes\n");
else printf("No\n");
}
}
return 0;
}
LRU Algorithm Gym - 102394L (HASH)的更多相关文章
- 哈希(Hash)与加密(Encrypt)相关内容
1.哈希(Hash)与加密(Encrypt)的区别 哈希(Hash)是将目标文本转换成具有相同长度的.不可逆的杂凑字符串(或叫做消息摘要),而加密(Encrypt)是将目标文本转换成具有不同长度的.可 ...
- 数据结构之哈希(hash)表
最近看PHP数组底层结构,用到了哈希表,所以还是老老实实回去看结构,在这里去总结一下. 1.哈希表的定义 这里先说一下哈希(hash)表的定义:哈希表是一种根据关键码去寻找值的数据映射结构,该结构通过 ...
- redis学习-散列表常用命令(hash)
redis学习-散列表常用命令(hash) hset,hmset:给指定散列表插入一个或者多个键值对 hget,hmget:获取指定散列表一个或者多个键值对的值 hgetall:获取所欲哦键值以及 ...
- 【Redis】命令学习笔记——哈希(hash)(15个超全字典版)
本篇基于redis 4.0.11版本,学习哈希(hash)相关命令. hash 是一个string类型的field和value的映射表,特别适合用于存储对象. 序号 命令 描述 实例 返回 HSET ...
- 《数据结构与算法分析——C语言描述》ADT实现(NO.05) : 散列(Hash)
散列(Hash)是一种以常数复杂度实现查找功能的数据结构.它将一个关键词Key,通过某种映射(哈希函数)转化成索引值直接定位到相应位置. 实现散列有两个关键,一是哈希函数的选择,二是冲突的处理. 对于 ...
- HDU 1880 魔咒词典 (Hash)
魔咒词典 Time Limit: 8000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- 哈希(hash)理解
转载自https://www.cnblogs.com/mingaixin/p/4318837.html 一.什么是哈希?(一种更复杂的映射) Hash,一般翻译做“散列”,也有直接音译为“哈希”的,就 ...
- ruby 对象转换哈希(Hash)
通过 ActiveRecord 从数据库的某张数据表(table)中获取的对象如何转换成为 Hash orders_table 是一张订单信息表,对应的 model 为 Orders @order = ...
- 哈希表(hash)详解
哈希表结构讲解: 哈希表(Hash table,也叫散列表),是根据关键码值(Key value)而直接进行访问的数据结构.也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度. ...
随机推荐
- 第28课 “共享状态”提供者(std::promise/std::package_task)
一. std::promise和std::package_task (一)共享状态.提供者和管理者 // CLASS TEMPLATE _Promise template <class _Ty& ...
- SqlServer 通过日志恢复数据库
前期工作 查看数据属性,确保下条件: 1.数据库属性->选项->恢复模式=完整 2.建好库以后.一个数据库完整的数据备份 3.到出事期间日志没有你间断 4.记录出事的准确时间 一.数据准备 ...
- Failed to start LSB: Bring up/down networking 另外一个偏方
之前网卡启动不了,会是配置不对,或者是移动了虚拟机导致hwaddr发生了变化. 但是今天没改动什么,突然用不了,一直报错Failed to start LSB: Bring up/down .... ...
- Redis(序)应用场景
前言 在阅读了<大型网站技术架构:核心原理与案例分析>书后,稍微了解了Redis在大型网站架构中的应用场景和目的. 大型网站都是从小用户量,小流量的网站演变过来的,在小型网站的架构之初,L ...
- navicat for mongodb12破解
网上搜了一圈,都不管用.大多都有病毒,最后还是通过搜索github解决问题. 破解文件:https://github.com/DoubleLabyrinth/navicat-keygen/releas ...
- sql 按指定规则排序,例如 按 1,3,2排序 而不是1,2,3
我们都知道 sql语句中的排序有desc(降序).asc(升序),这两个都是按顺序排列的,最近有一个需求是不按顺序排序了 ,抽出个别的排在前面,并且这种需求是应对的问题中的数据是比较少的,而且没有规律 ...
- Winform c# 多线程处理实例
我们在用C# 开发程序时,经常会使用的多线程,实现多任务的处理.一般常用的方法是新建多个线程,进行处理. 今天我分享一个采用线程池的方式来实现的实例.对有需要的朋友做个借鉴. 实例: Winform ...
- 性能监控工具的配置及使用 - Spotlight On Oracle(oracle)
一. Spotlight On Oracle(oracle)1.1. 工具简介Spotlight是一个强有力的Oracle数据库实时性能诊断工具,提供了一个直观的.可视化的数据库活动展现.S ...
- Delphi - 利用TRzTrayIcon实现WinFrm工程最小化到托盘
第三方RC控件的安装 浏览器搜索Delphi Rz控件下载,找到下载一个安装文件,解压后点击RC3.exe一键安装. Delphi WinFrm工程最小化到托盘 Delphi新建WinFrm工程,在主 ...
- FreeBSD虚拟机 VMware Tools 安装教程
对于 FreeBSD 虚拟机,您可以使用命令行工具手动安装或升级 VMware Tools 前提条件 开启虚拟机. 确认客户机操作系统正在运行. 因为 VMware Tools 安装程序是使用 Per ...