BZOJ 2527 [Poi2011]Meteors:整体二分
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2527
题意:
有n个国家和m个空间站,每个空间站都属于一个国家,一个国家可以有多个空间站,所有空间站按照顺序形成一个环,也就是说,m号空间站和1号空间站相邻。
现在,将会有k场流星雨降临,每一场流星雨都会给区间[li,ri]内的每个空间站带来ai单位的陨石,每个国家都有一个收集陨石的目标pi,即第i个国家需要收集pi单位的陨石。
询问:每个国家最早完成陨石收集目标是在第几场流星雨过后。
1<=n,m,k<=300000
题解:
整体二分。
将所有的国家一起二分。
对于当前的答案区间[l,r],先模拟下前mid场的流星雨,用树状数组维护。
再将已经超出目标pi的国家放到左边;把没达到目标的放在右边,并将这些国家的需求减去已经收集到的数量。
然后恢复刚才的流星雨,带上相应的国家,分别左右递归。
当访问到叶子节点的时候(即l==r),当前存的国家的答案即为l。
AC Code:
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <vector>
#define MAX_N 300005
#define INF 100000000 using namespace std; int n,m,t;
int ct[MAX_N];
int nd[MAX_N];
int L[MAX_N];
int R[MAX_N];
int a[MAX_N];
int ans[MAX_N];
long long sum[MAX_N];
long long dat[MAX_N];
vector<int> sp[MAX_N]; void update(int k,int x)
{
while(k>)
{
dat[k]+=x;
k-=k&-k;
}
} long long query(int k)
{
long long sum=;
while(k<=m)
{
sum+=dat[k];
k+=k&-k;
}
return sum;
} void section(int l,int r,int x)
{
update(r,x);
update(l-,-x);
} void meteor(int x,int f)
{
if(L[x]<=R[x]) section(L[x],R[x],a[x]*f);
else section(L[x],m,a[x]*f),section(,R[x],a[x]*f);
} void read()
{
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)
{
scanf("%d",&ct[i]);
sp[ct[i]].push_back(i);
}
for(int i=;i<=n;i++)
{
scanf("%d",&nd[i]);
}
scanf("%d",&t);
for(int i=;i<=t;i++)
{
scanf("%d%d%d",&L[i],&R[i],&a[i]);
}
t++;
L[t]=; R[t]=t; a[t]=INF;
} void dfs(vector<int> v,int l,int r)
{
if(l==r)
{
for(int i=;i<v.size();i++)
{
ans[v[i]]=l;
}
return;
}
vector<int> vl,vr;
int mid=(l+r)>>;
for(int i=l;i<=mid;i++)
{
meteor(i,);
}
for(int i=;i<v.size();i++)
{
sum[v[i]]=;
}
for(int i=;i<v.size();i++)
{
for(int j=;j<sp[v[i]].size() && sum[v[i]]<nd[v[i]];j++)
{
int temp=sp[v[i]][j];
sum[v[i]]+=query(temp);
}
}
for(int i=;i<v.size();i++)
{
if(sum[v[i]]>=nd[v[i]]) vl.push_back(v[i]);
else nd[v[i]]-=sum[v[i]],vr.push_back(v[i]);
}
for(int i=l;i<=mid;i++)
{
meteor(i,-);
}
dfs(vl,l,mid);
dfs(vr,mid+,r);
} void solve()
{
memset(dat,,sizeof(dat));
vector<int> v;
for(int i=;i<=n;i++) v.push_back(i);
dfs(v,,t);
} void print()
{
for(int i=;i<=n;i++)
{
if(ans[i]==t) printf("NIE\n");
else printf("%d\n",ans[i]);
}
} int main()
{
read();
solve();
print();
}
BZOJ 2527 [Poi2011]Meteors:整体二分的更多相关文章
- bzoj 2527: [Poi2011]Meteors 整体二分
给每个国家建一个链表,这样分治过程中的复杂度就和序列长度线形相关了,无脑套整体二分就可以. (最坑的地方是如果所有位置都是一个国家,那么它的样本个数会爆longlong!!被这个坑了一次,大于p[i] ...
- BZOJ 2527 [Poi2011]Meteors (整体二分+树状数组)
整体二分板题,没啥好讲的-注意是个环-还有所有贡献会爆longlong,那么只要在加之前判断一下有没有达到需要的值就行了- CODE #include <set> #include < ...
- 2527: [Poi2011]Meteors[整体二分]
2527: [Poi2011]Meteors Time Limit: 60 Sec Memory Limit: 128 MB Submit: 1528 Solved: 556 [Submit][S ...
- BZOJ.2527.[POI2011]MET-Meteors(整体二分)
题目链接 BZOJ 洛谷 每个国家的答案可以二分+求前缀和,于是可以想到整体二分. 在每次Solve()中要更新所有国家得到的值,不同位置的空间站对应不同国家比较麻烦. 注意到每次Solve()其国家 ...
- BZOJ 2527 [POI2011]MET-Meteors (整体二分+树状数组)
题目大意:略 洛谷传送门 整体二分裸题 考虑只有一个国家的情况如何处理 对询问数量二分答案,暴力$O(m)$打差分,求前缀和验证,时间是$O(mlogK)$ 如果有$n$个国家,就是$O(nmlogK ...
- BZOJ 2527 [Poi2011]Meteors(整体二分)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2527 [题目大意] 有N个成员国.现在它发现了一颗新的星球, 这颗星球的轨道被分为M份 ...
- 【BZOJ2527】[Poi2011]Meteors 整体二分
[BZOJ2527][Poi2011]Meteors Description Byteotian Interstellar Union (BIU) has recently discovered a ...
- BZOJ2527[Poi2011]Meteors——整体二分+树状数组
题目描述 Byteotian Interstellar Union (BIU) has recently discovered a new planet in a nearby galaxy. The ...
- BZOJ2527 [Poi2011]Meteors 整体二分 树状数组
原文链接http://www.cnblogs.com/zhouzhendong/p/8686460.html 题目传送门 - BZOJ2527 题意 有$n$个国家. 太空里有$m$个太空站排成一个圆 ...
随机推荐
- hdu 3367 Pseudoforest(并查集)
题意:有一种叫作Pseudoforest的结构,表示在无向图上,每一个块中选取至多包含一个环的边的集合,又称“伪森林”.问这个集合中的所有边权之和最大是多少? 分析:如果没有环,那么构造的就是最大生成 ...
- Redis用LPUSH和RPOP实现消息队列
using System; using System.Collections.Generic; using System.Linq; using System.Text; using ServiceS ...
- iOS 日志系统 本地日志打包上传到服务器
日志系统主要包含两个部分 1.本地保存 我们知道NSLog打印的日志一般都是直接输出到控制台,开发人员可以在控制台直接看到实时打印的log,既然可以在控制台输出,那么能否将日志输出到其他地方呢,比如说 ...
- PHP运行环境之IIS FastCGI 进程意外退出解决办法
本机做了系统,结果之前装好的APACHE环境什么的都没了,不想费事了,这次直接使用WIN8自带的IIS功能了,安装完毕后提示FastCGI 进程意外退出解决办法,这是由于某些加载库加载失败的原因,这里 ...
- Python中使用 Selenium 实现网页截图实例
Selenium 是一个可以让浏览器自动化地执行一系列任务的工具,常用于自动化测试.不过,也可以用来给网页截图.目前,它支持 Java.C#.Ruby 以及 Python 四种客户端语言.如果你使用 ...
- unittest 结合 ddt
数据驱动测试ddt,使用的重点: 1.@ddt.ddt2.@ddt.data(*zip(range(10),range(10,20))) 注意一定要带* 3.@ddt.unpack # c ...
- [转]maven2中snapshot快照库和release发布库的区别和作用
Post by 铁木箱子 in 技术杂谈 on 2010-08-03 17:17 [转载声明] 转载时必须标注:本文来源于铁木箱子的博客http://www.mzone.cc[原文地址] 原文永久地址 ...
- MyEclipse中Save could not be completed
在MyEclipse下编程时,保存的时候,假设出现例如以下图所看到的错误: - 刘立 - 707903908的博客" src="http://img0.ph.126.net/9y4 ...
- Coursera machine learning 第二周 quiz 答案 Octave/Matlab Tutorial
https://www.coursera.org/learn/machine-learning/exam/dbM1J/octave-matlab-tutorial Octave Tutorial 5 ...
- TortoiseSVN与VisualSVN Server搭建SVN版本控制系统(转)
地址:http://www.cnblogs.com/xing901022/p/4399382.html