[BZOJ2527]Meteors
整体二分挺好玩的...学一发
这个询问显然是可以二分的,但每次都二分就会T爆,所以我们有了“整体”二分
每次处理一些询问,要求这些询问的答案一定在$[l,r]$中
先把$l$到$mid$的操作实施,那么当前TAK的询问答案一定在$[l,mid]$中,当前NIE的询问答案一定在$[mid+1,r]$中,对答案为$[mid+1,r]$的那些询问加上$[l,mid]$的修改所产生的影响后分治处理即可
开始时加上一个操作$(1,m,+\infty)$就可以处理NIE的情况了
直接用线段树会被卡常,因为是区间加,单点询问,所以差分后用树状数组做即可
#include<stdio.h> #include<vector> using namespace std; typedef long long ll; const int inf=1000000000; struct rain{ int l,r,d; rain(int a=0,int b=0,int c=0){l=a;r=b;d=c;} }R[300010]; vector<int>s[300010]; vector<int>::iterator it; int p[300010],q[300010],ans[300010],ql[300010],qr[300010],n,m; ll d[300010],las[300010]; int lowbit(int x){return x&-x;} void add(int x,int v){ while(x<=m){ d[x]+=v; x+=lowbit(x); } } void add(int l,int r,int v){ add(l,v); add(r+1,-v); } ll query(int x){ ll s=0; while(x){ s+=d[x]; x-=lowbit(x); } return s; } void solve(int h,int t,int l,int r){ if(h>t)return; int i,mid,cl,cr; ll tmp; if(l==r){ for(i=h;i<=t;i++)ans[q[i]]=l; return; } mid=(l+r)>>1; for(i=l;i<=mid;i++){ if(R[i].l<=R[i].r) add(R[i].l,R[i].r,R[i].d); else{ add(R[i].l,m,R[i].d); add(1,R[i].r,R[i].d); } } cl=cr=0; for(i=h;i<=t;i++){ tmp=0; for(it=s[q[i]].begin();it!=s[q[i]].end();it++){ tmp+=query(*it); if(tmp+las[q[i]]>=p[q[i]])break; } if(tmp+las[q[i]]>=p[q[i]]) ql[++cl]=q[i]; else{ las[q[i]]+=tmp; qr[++cr]=q[i]; } } for(i=1;i<=cl;i++)q[h+i-1]=ql[i]; for(i=1;i<=cr;i++)q[h+cl+i-1]=qr[i]; for(i=l;i<=mid;i++){ if(R[i].l<=R[i].r) add(R[i].l,R[i].r,-R[i].d); else{ add(R[i].l,m,-R[i].d); add(1,R[i].r,-R[i].d); } } solve(h,h+cl-1,l,mid); solve(h+cl,t,mid+1,r); } int main(){ int i,x,k; scanf("%d%d",&n,&m); for(i=1;i<=m;i++){ scanf("%d",&x); s[x].push_back(i); } for(i=1;i<=n;i++)scanf("%d",p+i); scanf("%d",&k); for(i=1;i<=k;i++)scanf("%d%d%d",&R[i].l,&R[i].r,&R[i].d); R[++k]=rain(1,m,inf); for(i=1;i<=n;i++)q[i]=i; solve(1,n,1,k); for(i=1;i<=n;i++){ if(ans[i]==k) puts("NIE"); else printf("%d\n",ans[i]); } }
[BZOJ2527]Meteors的更多相关文章
- 【BZOJ2527】[Poi2011]Meteors 整体二分
[BZOJ2527][Poi2011]Meteors Description Byteotian Interstellar Union (BIU) has recently discovered a ...
- 【bzoj2527】[Poi2011]Meteors(树状数组(单点查询,区间修改)+整体二分)
[bzoj2527][Poi2011]Meteors Description Byteotian Interstellar Union (BIU) has recently discovered a ...
- BZOJ2527: [Poi2011]Meteors
补一发题解.. 整体二分这个东西,一开始感觉复杂度不是很靠谱的样子 问了po姐姐,说套主定理硬干.. #include<bits/stdc++.h> #define ll long lon ...
- 【BZOJ-2527】Meteors 整体二分 + 树状数组
2527: [Poi2011]Meteors Time Limit: 60 Sec Memory Limit: 128 MBSubmit: 831 Solved: 306[Submit][Stat ...
- BZOJ2527 [Poi2011]Meteors 整体二分 树状数组
原文链接http://www.cnblogs.com/zhouzhendong/p/8686460.html 题目传送门 - BZOJ2527 题意 有$n$个国家. 太空里有$m$个太空站排成一个圆 ...
- 【BZOJ2527】【POI2011】Meteors [整体二分]
Meteors Time Limit: 60 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description 这个星球经常会下陨石雨.BI ...
- BZOJ2527[Poi2011]Meteors——整体二分+树状数组
题目描述 Byteotian Interstellar Union (BIU) has recently discovered a new planet in a nearby galaxy. The ...
- bzoj千题计划149:bzoj2527: [Poi2011]Meteors
http://www.lydsy.com/JudgeOnline/problem.php?id=2527 整体二分 区间加,单点查,树状数组维护差分序列 注意 累积可能会爆long long,所以一满 ...
- BZOJ2527 & 洛谷3527:[Poi2011]Meteors——题解
+++++++++++++++++++++++++++++++++++++++++++ +本文作者:luyouqi233. + +欢迎访问我的博客:http://www.cnblogs.com/luy ...
随机推荐
- 一个 React & Redux的目录树
|-----------------------------------------| | | | React & Redux | | | |------------------------- ...
- ACM模板~求第k短路 ~~~A*+Dijkstra
#include <map> #include <set> #include <cmath> #include <ctime> #include < ...
- 桥接物理网卡,pipwork指定ip,外网连接,研究salt+docker
1.桥接物理网卡: 首先下载工具: yum -y install --enablerepo=epel bridge-utils 停止服务: 983 systemctl stop docker 删除do ...
- is
MyType a = null; if (a is MyType) == False
- border-image
一.border-image的兼容性 border-image可以说是CSS3中的一员大将,将来一定会大放光彩,其应用潜力真的是非常的惊人.可惜目前支持的浏览器有限,仅 Firefox3.5,chro ...
- Android推送使用--文章集锦
Android之基于百度云推送IM Android实现推送方式解决方案 Android消息推送(一)--AndroidPn(XMPP协议)Demo版到正式上线 采用XMPP协议实现Android推送 ...
- oracle有关游标的知识
一:前言 今天我自己第二次写游标,我擦,觉得自己在数据库方面需要很大的提高啊.今天遇到三个问题,第一个是oracle数据库中的数据拆分的问题,这个我用regexp_substr来进行解决,第二个问题就 ...
- 设置查看java的源程序
1.点 “window”-> "Preferences" -> "Java" -> "Installed JRES" 2. ...
- win 7 64 位系统驱动签名
自己开发未经签名的驱动无法加载,关闭Windows 7系统中的驱动签名强制要求 bcdedit.exe -set loadoptions DDISABLE_INTEGRITY_CHECKS
- Java任务调度框架----kunka
初衷 工作中用到了很多框架,但是给我印象最深的还是我们PO(Product Owner)在若干年前写的一套任务调度框架,在JDK1.4之前,concurrent包还没有引入, 手写的这套Token调度 ...