BZOJ2527: [Poi2011]Meteors(整体二分)
Description
这个星球经常会下陨石雨。BIU已经预测了接下来K场陨石雨的情况。
BIU的第i个成员国希望能够收集Pi单位的陨石样本。你的任务是判断对于每个国家,它需要在第几次陨石雨之后,才能收集足够的陨石。
输入:
第一行是两个数N,M。
第二行有M个数,第i个数Oi表示第i段轨道上有第Oi个国家的太空站。
第三行有N个数,第i个数Pi表示第i个国家希望收集的陨石数量。
第四行有一个数K,表示BIU预测了接下来的K场陨石雨。
接下来K行,每行有三个数Li,Ri,Ai,表示第K场陨石雨的发生地点在从Li顺时针到Ri的区间中(如果Li<=Ri,就是Li,Li+1,...,Ri,否则就是Ri,Ri+1,...,m-1,m,1,...,Li),向区间中的每个太空站提供Ai单位的陨石样本。
输出:
N行。第i行的数Wi表示第i个国家在第Wi波陨石雨之后能够收集到足够的陨石样本。如果到第K波结束后仍然收集不到,输出NIE。
数据范围:
Input
Output
Sample Input
1 3 2 1 3
10 5 7
3
4 2 4
1 3 1
3 5 2
Sample Output
NIE
1
解题思路:
整体二分非常好的入门题。
整体二分就是最大化利用二分答案的空隙。
将询问分类,将midcheck后合法的统一右移左指针。
相当于递归栈中实现了棵树。
仔细想想也不无道理,建线段树时一起构建更加省时,这是一个道理,相当于更新环境来检查答案。
这道题就是将mid次陨石全部降下形成一个环境,合法则推入下一个环境。
代码:
#include<cstdio>
#include<vector>
#include<cstring>
#include<algorithm>
typedef long long lnt;
const int N=;
struct object{
int no;
lnt target;
std::vector<int>inp;
}o[N],sp[N],ss[N];
struct matter{
int l;
int r;
lnt val;
}is[N];
int n,m;
int cnt;
int top;
int ans[N];
int blg[N];
lnt line[N];
int lowbit(int x){return x&(-x);}
void update(int pos,lnt v){while(pos<=m){line[pos]+=v;pos+=lowbit(pos);}return ;}
lnt query(int pos){lnt ans=;while(pos){ans+=line[pos];pos-=lowbit(pos);}return ans;}
void occur(int dir,int which)
{
dir=dir*is[which].val;
if(is[which].l<=is[which].r)
{
update(is[which].l,dir);
update(is[which].r+,-dir);
}else{
update(,dir);
update(is[which].r+,-dir);
update(is[which].l,dir);
}
return ;
}
bool check(int no)
{
lnt ret=;
lnt tar=o[no].target;
for(int i=;i<o[no].inp.size();i++)
{
ret+=query(o[no].inp[i]);
if(ret>=tar)
return true;
}
return ret>=tar;
}
void macrs(int l,int r,int ll,int rr)
{
if(ll>rr)
return ;
if(l==r)
{
for(int i=ll;i<=rr;i++)
ans[o[i].no]=l;
return ;
}
int mid=(l+r)>>;
while(top<=mid)
occur(,++top);
while(top>mid)
occur(-,top--);
int sta1=,sta2=;
for(int i=ll;i<=rr;i++)
{
if(check(i))
sp[++sta1]=o[i];
else
ss[++sta2]=o[i];
}
int sta=ll-;
int lmid;
for(int i=;i<=sta1;i++)
o[++sta]=sp[i];
lmid=sta;
for(int i=;i<=sta2;i++)
o[++sta]=ss[i];
macrs(l,mid,ll,lmid);
macrs(mid+,r,lmid+,rr);
return ;
}
int main()
{
//freopen("7.in","r",stdin);
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)
{
scanf("%d",&blg[i]);
o[blg[i]].inp.push_back(i);
}
for(int i=;i<=n;i++)
{
ans[i]=-;
scanf("%lld",&o[i].target);
o[i].no=i;
}
scanf("%d",&cnt);
for(int i=;i<=cnt;i++)
scanf("%d%d%lld",&is[i].l,&is[i].r,&is[i].val);
is[++cnt]=(matter){,m,0x3f3f3f3f};
macrs(,cnt,,n);
for(int i=;i<=n;i++)
if(ans[i]==-||ans[i]==cnt)
printf("NIE\n");
else
printf("%d\n",ans[i]);
return ;
}
BZOJ2527: [Poi2011]Meteors(整体二分)的更多相关文章
- BZOJ2527 [Poi2011]Meteors 整体二分 树状数组
原文链接http://www.cnblogs.com/zhouzhendong/p/8686460.html 题目传送门 - BZOJ2527 题意 有$n$个国家. 太空里有$m$个太空站排成一个圆 ...
- BZOJ2527[Poi2011]Meteors——整体二分+树状数组
题目描述 Byteotian Interstellar Union (BIU) has recently discovered a new planet in a nearby galaxy. The ...
- 【BZOJ2527】[Poi2011]Meteors 整体二分
[BZOJ2527][Poi2011]Meteors Description Byteotian Interstellar Union (BIU) has recently discovered a ...
- 【bzoj2527】[Poi2011]Meteors 整体二分+树状数组
题目描述 有N个成员国.现在它发现了一颗新的星球,这颗星球的轨道被分为M份(第M份和第1份相邻),第i份上有第Ai个国家的太空站. 这个星球经常会下陨石雨.BIU已经预测了接下来K场陨石雨的情况.BI ...
- [bzoj2527][Poi2011]Meteors_整体二分_树状数组
Meteors bzoj-2527 Poi-2011 题目大意:题目链接. 注释:略. 想法: 首先答案可以离线,且具有单调性. 这里的单调性就是随着时间的推移,每个国家收集的陨石数增加. 不难想到整 ...
- 【BZOJ-2527】Meteors 整体二分 + 树状数组
2527: [Poi2011]Meteors Time Limit: 60 Sec Memory Limit: 128 MBSubmit: 831 Solved: 306[Submit][Stat ...
- 2527: [Poi2011]Meteors[整体二分]
2527: [Poi2011]Meteors Time Limit: 60 Sec Memory Limit: 128 MB Submit: 1528 Solved: 556 [Submit][S ...
- bzoj 2527: [Poi2011]Meteors 整体二分
给每个国家建一个链表,这样分治过程中的复杂度就和序列长度线形相关了,无脑套整体二分就可以. (最坑的地方是如果所有位置都是一个国家,那么它的样本个数会爆longlong!!被这个坑了一次,大于p[i] ...
- Luogu3527 POI2011 Meteors 整体二分、树状数组、差分
传送门 比较板子的整体二分题目,时限有点紧注意常数 整体二分的过程中将时间在\([l,mid]\)之间的流星使用树状数组+差分进行维护,然后对所有国家查看一遍并分好类,递归下去,记得消除答案在\([m ...
随机推荐
- Java之——删除ArrayList中的反复元素的2种方法
转载请注明出处:http://blog.csdn.net/l1028386804/article/details/47414935 ArrayList是Java中最经常使用的集合类型之中的一个.它同意 ...
- 78.Nodejs基础中间件Connect
转自:https://www.cnblogs.com/chris-oil/p/5625437.html 前言 “中间件”在软件领域是一个非常广的概念,除操作系统的软件都可以称为中间件,比如,消息中间件 ...
- 9.java 操作mongodb插入、读取、修改以及删除基础
1 package mongodb; import java.net.UnknownHostException; import java.util.ArrayList; import java.uti ...
- MySql免安装版绿化版安装配置,附MySQL服务无法启动解决方案
整理于:https://www.cnblogs.com/cenwei/p/6249856.html 我下载的MySQL版本是:mysql-5.6.15-winx64 一.解压文件 下载好My ...
- vue父子间通信案列三($emit和prop用法)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Aspose.Cells相应操作及下载
Aspose.Cells相应操作 1,上传 1.1 Workbook Workbook workBook = new Workbook(); 属性: 名称 值类型 说明 Colors Color[] ...
- Windows10 Linux子系统的启用和中文用户名的修改
一直用的虚拟机Linux,忽然心血来潮,看到Windows 10可以使用Linux子系统,于是来装一波,按照这位前辈的教程 https://blog.csdn.net/zhangdongren/art ...
- TCP简单说|(上)
本文在Creative Commons许可证下发布 TCP是一个巨复杂的协议,因为他要解决很多问题,而这些问题又带出了很多子问题和阴暗面.所以学习TCP本身是个比较痛苦的过程,但对于学习的过程却能让人 ...
- UIWebView 无缝切换到 WKWebView
WKWebView 是IOS8新增的 Web浏览视图 长处: 载入速度 比UIWebView提升差点儿相同一倍的, 内存使用上面,反而还少了一半. 缺点: WKWebView 不支持缓存 和 ...
- 什么是PV和UV?
技术角度 1个PV是指从浏览器发出一个对网络server的Request,网络server接到Request之后.会開始把该Request相应的一个Page(Page就是一个网页)发送到client的 ...