CodePlus2017 12月月赛 div2火锅盛宴
当时看到这道题感觉真是难过,我数据结构太弱啦。
我们来看看需要求什么:
1、当前熟了的食物的最小id
2、当前熟了的食物中有没有编号为id的食物
3、当前没熟的食物中有没有编号为id的食物
4、当前没熟的食物中编号为id的食物最接近煮熟的还需要多久才会熟
5、当前熟了的食物中编号在[l,r]之间的有多少个
我们需要维护的操作是:
1、往当前的锅里面加一个编号为id的生食物
2、每个时刻锅里面哪些生的食物要变熟
3、吃掉(删除)一个熟了的食物
感觉这种题真考人做题的毅力,求的东西好杂感觉脑子里都乱套了。
我用了4个multiset+1个树状数组来水这道题。
4个multiset:
Hn : 存int,当前没熟的的食物的id(按照id顺序)
Hn2 : 存结构体,当前没熟的食物的id和熟的时间(按照熟的时间顺序)
now[maxn] : 存int,now[i]是id为i的未熟食物的熟的时间(按照熟的时间顺序)
Hd : 存int,当前熟了的食物的id(按照id顺序)
剩下还有一个树状数组用来求id在一个区间的熟了的食物的个数的。
感觉非常不优秀,但是当时剩下时间不多,就没有怎么优化。
注意multiset如果直接erase(x)会把所有值为x的都删掉,只删一个需要先find,再删。(感谢Achen)
//Serene
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<set>
using namespace std;
const int maxn=1e5+10,maxm=5e5+10;
int n,m,T,s[maxn]; struct Node{
int id,time;
Node() {}
Node(int id,int time):id(id),time(time){}
bool operator < (const Node& b) const{
return time < b.time;
}
}; multiset<int> Hn;
multiset<Node> Hn2;
multiset<Node>::iterator it;
multiset<int>::iterator it2;
multiset<int> Hd;
multiset<int> now[maxn]; int aa;char cc;
int read() {
aa=0;cc=getchar();
while(cc<'0'||cc>'9') cc=getchar();
while(cc>='0'&&cc<='9') aa=aa*10+cc-'0',cc=getchar();
return aa;
} int sz[maxn];
void chge(int pos,int x) {
while(pos<=n) {
sz[pos]+=x;
pos+=pos&-pos;
}
} int q(int pos) {
int rs=0;
while(pos) {
rs+=sz[pos];
pos-=pos&-pos;
}
return rs;
} int main() {
T=read(); int t,op,l,r,x;
while(T--) {
Hn.clear(); Hn2.clear(); Hd.clear();
for(int i=1;i<=n;++i) now[i].clear();
memset(sz,0,sizeof(sz));
n=read();
for(int i=1;i<=n;++i) s[i]=read();
m=read();
while(m--) {
t=read(); op=read();
while(!Hn2.empty()) {
it=Hn2.begin();
if(it->time>t) break;
x=it->id;
it2=Hn.find(x);
Hn.erase(it2);
Hd.insert(x);
Hn2.erase(it);
chge(x,1);
while(!now[x].empty()) {
it2=now[x].begin();
if(*it2>t) break;
now[x].erase(it2);
}
}
if(op==0) {
x=read();
Hn2.insert(Node(x,t+s[x]));
Hn.insert(x);
now[x].insert(t+s[x]);
}
else if(op==1) {
if(Hd.empty()) {
printf("Yazid is angry.\n");
continue;
}
it2=Hd.begin();
printf("%d\n",*it2);
chge(*it2,-1);
Hd.erase(it2);
}
else if(op==2) {
x=read();
if((it2=Hd.find(x))!=Hd.end()) {
printf("Succeeded!\n");
chge(*it2,-1);
Hd.erase(it2);
}
else if(Hn.find(x)!=Hn.end()) {
it2=now[x].begin();
printf("%d\n",*it2-t);
}
else printf("YJQQQAQ is angry.\n");
}
else if(op==3) {
l=read(); r=read();
printf("%d\n",q(r)-q(l-1));
}
}
}
return 0;
}
CodePlus2017 12月月赛 div2火锅盛宴的更多相关文章
- CodePlus2017 12月月赛 div2可做题2
11月的月赛错过了,来打12月月赛,由于很(zi)想(ji)拿(tai)衣(ruo)服(la),所以去打div2. T1是一个sb模拟,但是机房全卡死在这道语文题上了,基本上弄了一个半小时,T2可以秒 ...
- code+12月月赛 火锅盛宴
时间限制: 2.0 秒 空间限制: 512 MB 题目背景 SkyDec和YJQQQAQ都是Yazid的好朋友.他们都非常喜欢吃火锅.有一天,他们聚在一起,享受一场火锅盛宴. 题目描述 在这场火锅盛宴 ...
- 「CodePlus 2017 12 月赛」火锅盛宴(模拟+树状数组)
1A,拿来练手的好题 用一个优先队列按煮熟时间从小到大排序,被煮熟了就弹出来. 用n个vector维护每种食物的煮熟时间,显然是有序的. 用树状数组维护每种煮熟食物的数量. 每次操作前把优先队列里煮熟 ...
- 「CodePlus 2017 12 月赛」火锅盛宴
n<=100000种食物,给每个食物煮熟时间,有q<=500000个操作:在某时刻插入某个食物:查询熟食中编号最小的并删除之:查询是否有编号为id的食物,如果有查询是否有编号为id的熟食, ...
- 洛谷3月月赛div2 题解(模拟+数学+贪心+数学)
由于本人太蒻了,div1的没有参加,胡乱写了写div2的代码就赶过来了. T1 苏联人 题目背景 题目名称是吸引你点进来的. 这是一道正常的题,和苏联没有任何关系. 题目描述 你在打 EE Round ...
- CSU 2018年12月月赛 B 2214: Sequence Magic
Description 有一个1到N的自然数序列1,2,3,...,N-1,N. 我们对它进行M次操作,每次操作将其中连续的一段区间 [Ai,Bi][Ai,Bi] (即第Ai个元素到第Bi个元素之间的 ...
- 最大字段和&洛谷11月月赛DIV2 T1
蒟蒻只能打一打DIV2的基础题 太卑微了 这道题的本质其实是再建一个数组,如果s串i位置是0那么就给a[i]赋值为1,表示要累加个数,如果是1那么就把a[i]赋值为-1,表示个数减一,最后求最大子段和 ...
- 安恒X计划12月月赛
ezweb 主要是序列化问题.没有PHP环境,在线运行的.实例化对象之后修改一下file.然后echo输出序列化的结果.不过下面有一个正则检查.数字前加一个+,影响了正则的匹配,但是对于序列化的还原没 ...
- CSU 2018年12月月赛 H(2220): Godsend
Description Leha somehow found an array consisting of n integers. Looking at it, he came up with a t ...
随机推荐
- Luogu P2845 [USACO15DEC]Switching on the Lights 开关灯(bfs)
P2845 [USACO15DEC]Switching on the Lights 开关灯 题意 题目背景 来源:usaco-2015-dec \(Farm\ John\)最近新建了一批巨大的牛棚.这 ...
- Leetcode951. Flip Equivalent Binary Trees翻转等价二叉树
我们可以为二叉树 T 定义一个翻转操作,如下所示:选择任意节点,然后交换它的左子树和右子树. 只要经过一定次数的翻转操作后,能使 X 等于 Y,我们就称二叉树 X 翻转等价于二叉树 Y. 编写一个判断 ...
- lc6 ZigZag Conversion
lc6 ZigZag Conversion 分成两步, 第一步垂直向下, 1 1 1 1 第二步倾斜向上 1 1 1 1 1 1 1 用nRows个StringBuilder 然后将他们合并即可 cl ...
- Makefile知识点
1.标准Makefile文件示例如下: #把.o .C .cxx .cpp .hxx .h添加到后缀列表中. .SUFFIXES: .o .C .cxx .cpp .hxx .h #设置变量并赋值,方 ...
- jqurey相册放大浏览效果。
/*图片弹窗与切换*/ function honorLayer(){ var honorArray = honorArr(); var $msk = $('.js-mask'),$layer = $( ...
- linux下mysql的配置问题
设置MySQL 复制以下配置信息到新建的my.ini(windows下的文件)文件中. [mysqld] # 设置3306端口 port= # 设置mysql的安装目录 basedir=D:\Prog ...
- PHP+Ajax点击加载更多内容 -这个效果好,速度快,只能点击更多加载,不能滚动自动加载
这个效果好,速度快,只能点击更多加载,不能滚动自动加载 一.HTML部分 <div id="more"> <div class="single_item ...
- Java程序员面试题收集(5)
Java基础方面: 1.作用域public,private,protected,以及不写时的区别 答:区别如下: 作用域 当前类 同一package 子孙类 其他package public √ √ ...
- spring定时任务scheduler集群环境下指定运行服务器防止多服务器多次执行
使用spring的@Scheduler注解可以非常方便的启动一个定时任务,但是当服务部署在多台服务器上做负载均衡的时候,可能会出现重复执行的情况. 现在我们通过代码指定job只在某一台机器执行. 首先 ...
- 查看cpu性能和磁盘空间
df -h查看当前磁盘空间 du -sh查看当前目录占用的磁盘空间 du -sh * 查看当前所有目录占用的磁盘空间 lscpu查看cpu信息 free查看空间总量