#6085. 「美团 CodeM 资格赛」优惠券
用last[x]表示对x进行的上一次操作的位置,vis[x]表示x是否在大楼内。
Splay维护'?'的位置。
若x要进楼:
1.若x已在楼内,则去找last[x]到i之间是否有'?',若有,则可以把这个'?'当做是上一个x出楼,反之则 出现错误。
2.若x不在楼内,标记x在楼内。
若x要出楼:
1.若x在楼内,标记x不在楼内。
2.若x不在楼内,相同的去找last[x]到i之间是否有'?'。
#include<complex>
#include<cstdio>
using namespace std;
const int N=5e5+;
int n,sz,rot,ans=-;
int key[N],fat[N],son[N][],siz[N],last[N];
bool vis[N];
int qread()
{
int x=;
char ch=getchar();
while(ch<'' || ch>'')
{
if(ch=='I')return ;
if(ch=='O')return ;
if(ch=='?')return ;
ch=getchar();
}
while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
return x;
}
void Update(int rt)
{
siz[rt]=siz[son[rt][]]+siz[son[rt][]]+;
}
void Rotate(int x,int &rt)
{
int a=fat[x],b=fat[a],l=son[a][]==x,r=l^;
if(a==rt)rt=x;
else son[b][son[b][]==a]=x;
fat[son[x][r]]=a;fat[a]=x;fat[x]=b;
son[a][l]=son[x][r];son[x][r]=a;
Update(a);Update(x);
}
inline void Splay(int x,int &rt)
{
while(x!=rt)
{
int a=fat[x],b=fat[a];
if(a!=rt)
if((son[a][]==x)^(son[b][]==a))
Rotate(x,rt);
else Rotate(a,rt);
Rotate(x,rt);
}
}
void Insert(int v,int k)
{
int fa=;
while(k && key[k]!=v)
fa=k,k=son[k][key[k]<v];
k=++sz;
key[k]=v;siz[k]=;fat[k]=fa;
if(fa)son[fa][key[fa]<v]=k;
Splay(k,rot);
}
void Find(int x,int k)
{
while(son[k][key[k]<x] && x!=key[k])
k=son[k][key[k]<x];
Splay(k,rot);
}
void Delete(int x)
{
Find(x,rot);
if(son[rot][] && son[rot][])
{
int tmp=rot,k=son[rot][];
rot=k;
while(son[k][])k=son[k][];
siz[k]+=siz[son[tmp][]];
fat[son[tmp][]]=k;son[k][]=son[tmp][];
Splay(k,rot);
}
else rot=son[rot][]+son[rot][];
fat[rot]=;
}
int GetNxt(int x)
{
Find(x,rot);
if(key[rot]>x)return rot;
int k=son[rot][];
while(son[k][])k=son[k][];
return k;
}
int main()
{
scanf("%d",&n);
int tmp,p,x;
for(int i=;i<=n;i++)
{
p=qread();
if(p==)
{
x=qread();
if(vis[x])
{
tmp=key[GetNxt(last[x])];
if(!tmp)
{
ans=i;
break;
}
else Delete(tmp);
}
vis[x]=;
last[x]=i;
}
if(p==)
{
x=qread();
if(!vis[x])
{
tmp=key[GetNxt(last[x])];
if(!tmp)
{
ans=i;
break;
}
else Delete(tmp);
}
vis[x]=;
last[x]=i;
}
if(p==)Insert(i,rot);
}
printf("%d\n",ans);
return ;
}
#6085. 「美团 CodeM 资格赛」优惠券的更多相关文章
- LOJ#6085. 「美团 CodeM 资格赛」优惠券(set)
题意 题目链接 Sol 考虑不合法的情况只有两种: 进去了 再次进去 没进去 但是出来了 显然可以用未知记录抵消掉 直接开个set维护一下所有未知记录的位置 最优策略一定是最后一次操作位置的后继 同时 ...
- loj 6085.「美团 CodeM 资格赛」优惠券
题目: 一个有门禁的大楼,初始时里面没有人. 现在有一些人在进出大楼,每个人都有一个唯一的编号.现在有他们进出大楼的记录,但是有些被污染了,只能知道这里有一条记录,具体并不能知道. 一个人只有进大楼, ...
- 「题解」「美团 CodeM 资格赛」跳格子
目录 「题解」「美团 CodeM 资格赛」跳格子 题目描述 考场思路 思路分析及正解代码 「题解」「美团 CodeM 资格赛」跳格子 今天真的考自闭了... \(T1\) 花了 \(2h\) 都没有搞 ...
- 「美团 CodeM 资格赛」跳格子
题目描述 nnn 个格子排成一列,一开始,你在第一个格子,目标为跳到第 n 个格子.在每个格子 i 里面你可以做出两个选择: 选择「a」:向前跳 ai 步. 选择「b」:向前跳 bi 步. 把每步 ...
- 「美团 CodeM 资格赛」试题泛做
LibreOJ真是吼啊! 数码 推个式子,把枚举因数转为枚举倍数.然后就发现它是根号分段的.然后每一段算一下就好了. #include <cstdio> #include <cstr ...
- loj 6084.「美团 CodeM 资格赛」跳格子
题目: link 题解: 尽量走\(a\). 只要保证走\(a\)后到达的点一定可以到终点就可以走. 所以从终点开始\(dfs\)出所有能够到达终点的点. 然后再从起点开始\(dfs\)路径即可. 如 ...
- loj 6083.「美团 CodeM 资格赛」数码
题目: 给定两个整数\(l\)和\(r\),对于任意\(x\),满足\(l\leq x\leq r\),把\(x\)所有约数写下来. 对于每个写下来的数,只保留最高位的那个数码.求\([1,9]\)中 ...
- LOJ #6192. 「美团 CodeM 复赛」城市网络 (树上倍增)
#6192. 「美团 CodeM 复赛」城市网络 内存限制:64 MiB 时间限制:500 ms 标准输入输出 题目描述 有一个树状的城市网络(即 nnn 个城市由 n−1n-1n−1 条道路连接 ...
- LibreOJ #6192. 「美团 CodeM 复赛」城市网络
#6192. 「美团 CodeM 复赛」城市网络 内存限制:64 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: sqc 提交提交记录统计讨论测试数据 题目描 ...
随机推荐
- xxx商城之商品管理
- UOJ269 清华集训2016 如何优雅地求和 下降幂多项式、NTT
代码 神仙题? 看到连续的点值,那么一定是要利用到连续点值的性质,可以考虑下降幂多项式,即考虑多项式\(F(x) = \sum\limits_{i=0}^m a_ix^{\underline i}\) ...
- MySql取消密码强度验证功能
一.修改MySql配置文件(my.cnf)一般情况下,MySql的配置文件 my.cnf 会在 /etc/ 目录下,如果没有,可以使用以下命令查找位置: find / -name my.cnf 编辑 ...
- 关于python、pip、anaconda安装的一些记录
写这篇博客是因为自己这段时间总是倒腾python的环境,其间倒腾崩了好几次.....无奈之下还是梳理一下. PYTHON 首在安装python3.6的之后,我安装了anaconda3,这样我的电脑上p ...
- .Net Core 注入学习——注册服务
解析 .Net Core 注入——注册服务发表于:2017-10-23 10:47 作者:行走即歌 来源:51Testing软件测试网采编字体:大 中 小 | 上一篇 | 下一篇 |我要投稿 | 推荐 ...
- RESTful 的学习总结
RESTful 的核心思想就是,客户端发出的数据操作指令都是"动词 + 宾语"的结构.比如,GET /articles这个命令,GET是动词,/articles是宾语.动词通常就是 ...
- Visual Studio 2019 使用.Net Core 3.0 一
一.前言 早在很久之前微软便公布 .NET Core 3.0 将支持开发Winform应用程序等等新特性,现如今 .NET Core 3.0 预览版已经出来第八个预览版了,从 .NET Core 2. ...
- 74.js---移动端文章的瀑布流的实现。
移动端文章的瀑布流的实现. 1.首先在前端html页面已经通过PHP代码循环完全数据. 2.然后在js先全部隐藏,通过判断滑动到底部,每次加载一部分数据,直到数据全部显示完全. js代码: // ...
- python多进程并行代码
from multiprocessing import Process import sys, os import time def timetask(string): while True: pri ...
- Ceph集群部署(基于Luminous版)
环境 两个节点:ceph0.ceph1 ceph0: mon.a.mds.mgr.osd.0.osd.1 ceph1: mon.b.osd.2.osd.3 操作系统:ubuntu14.04 网络配置: ...