【BZOJ2527】MET-Meteors(整体二分)

题面

BZOJ权限题,良心洛谷链接

题解

其实我也不会做

看了zsy博客才会做。。。

这题如果直接爆算做显然行不通

如果只有单次询问,我们就可以二分答案

但是询问太多。。

不会二分。。

怎么办?

我们来想想瓶颈在哪里

如果每次都进行一次单次二分

我们就需要不停的计算前缀和

但是其实再进行别的二分的时候我们已经算过了

这里就算重了

怎么解决?

那我们就不让他算重:

我们把所有询问一起二分

这样每次计算完之后

所有的询问就被分成了两部分:

一部分是当前二分值有解

另一部分是无解

这样就可以解决重复计算的问题了

因为要反复计算前缀和

所以使用树状数组来计算就行了

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<set>
#include<map>
#include<vector>
#include<queue>
using namespace std;
#define ll long long
#define RG register
#define MAX 320000
inline int read()
{
RG int x=0,t=1;RG char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=-1,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return x*t;
}
struct Rain{int l,r;ll w;}r[MAX];
ll c[MAX];
int n,m,ans[MAX],K;
int lowbit(int x){return x&(-x);}
void Add(int x,int w){while(x<=m)c[x]+=w,x+=lowbit(x);}
ll getsum(int x){ll ret=0;while(x)ret+=c[x],x-=lowbit(x);return ret;}
vector<int> a[MAX];
struct Query{int id;ll p;}p[MAX],p1[MAX],p2[MAX];
void Fall(int t,int opt)
{
if(r[t].l>r[t].r)Add(1,opt*r[t].w);
Add(r[t].l,opt*r[t].w),Add(r[t].r+1,-opt*r[t].w);
}
void Work(int l,int r,int L,int R)
{
if(L>R)return;
if(l==r)
{
for(int i=L;i<=R;++i)ans[p[i].id]=l;
return;
}
int mid=(l+r)>>1;
ll tot;
int t1=0,t2=0;
for(int i=l;i<=mid;++i)Fall(i,1);
for(int i=L;i<=R;++i)
{
tot=0;
for(int j=0,l=a[p[i].id].size();j<l;++j)tot+=getsum(a[p[i].id][j]);
if(tot>=p[i].p)p1[++t1]=p[i];
else p[i].p-=tot,p2[++t2]=p[i];
}
for(int i=l;i<=mid;++i)Fall(i,-1);
for(int i=1;i<=t1;++i)p[i+L-1]=p1[i];
for(int i=1;i<=t2;++i)p[i+L+t1-1]=p2[i];
Work(l,mid,L,L+t1-1);
Work(mid+1,r,L+t1,R);
}
int main()
{
n=read();m=read();
for(int i=1;i<=m;++i)a[read()].push_back(i);
for(int i=1;i<=n;++i)p[i].p=read(),p[i].id=i;
K=read();
for(int i=1;i<=K;++i)r[i].l=read(),r[i].r=read(),r[i].w=read();
++K;r[K]=(Rain){1,m,1e9};
Work(1,K,1,n);
for(int i=1;i<=n;++i)ans[i]==K?puts("NIE"):printf("%d\n",ans[i]);
return 0;
}

【BZOJ2527】MET-Meteors(整体二分)的更多相关文章

  1. 【BZOJ-2527】Meteors 整体二分 + 树状数组

    2527: [Poi2011]Meteors Time Limit: 60 Sec  Memory Limit: 128 MBSubmit: 831  Solved: 306[Submit][Stat ...

  2. BZOJ2527 [Poi2011]Meteors 整体二分 树状数组

    原文链接http://www.cnblogs.com/zhouzhendong/p/8686460.html 题目传送门 - BZOJ2527 题意 有$n$个国家. 太空里有$m$个太空站排成一个圆 ...

  3. BZOJ2527[Poi2011]Meteors——整体二分+树状数组

    题目描述 Byteotian Interstellar Union (BIU) has recently discovered a new planet in a nearby galaxy. The ...

  4. BZOJ2527: [Poi2011]Meteors(整体二分)

    Description Byteotian Interstellar Union (BIU) has recently discovered a new planet in a nearby gala ...

  5. 【BZOJ2527】[Poi2011]Meteors 整体二分

    [BZOJ2527][Poi2011]Meteors Description Byteotian Interstellar Union (BIU) has recently discovered a ...

  6. 【BZOJ2527】【POI2011】Meteors [整体二分]

    Meteors Time Limit: 60 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description 这个星球经常会下陨石雨.BI ...

  7. 【bzoj2527】[Poi2011]Meteors 整体二分+树状数组

    题目描述 有N个成员国.现在它发现了一颗新的星球,这颗星球的轨道被分为M份(第M份和第1份相邻),第i份上有第Ai个国家的太空站. 这个星球经常会下陨石雨.BIU已经预测了接下来K场陨石雨的情况.BI ...

  8. [bzoj2527][Poi2011]Meteors_整体二分_树状数组

    Meteors bzoj-2527 Poi-2011 题目大意:题目链接. 注释:略. 想法: 首先答案可以离线,且具有单调性. 这里的单调性就是随着时间的推移,每个国家收集的陨石数增加. 不难想到整 ...

  9. bzoj 2527 Meteors - 整体二分 - 树状数组

    Description Byteotian Interstellar Union (BIU) has recently discovered a new planet in a nearby gala ...

  10. 2527: [Poi2011]Meteors[整体二分]

    2527: [Poi2011]Meteors Time Limit: 60 Sec  Memory Limit: 128 MB Submit: 1528  Solved: 556 [Submit][S ...

随机推荐

  1. angular2 localStorage的使用

    最近从ng1  转ng2     相信 使用ng1的同学都知道 ngStorage 这个插件吧,  存储 本地数据 下面介绍一下 ng2 使用 localStorage 参考 github https ...

  2. Shiro的原理及Web搭建

    shiro(java安全框架) 以下都是综合之前的人加上自己的一些小总结 Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授权.密码学和会话管理.使用Shiro的易于理解的A ...

  3. IntelliJ IDEA(八) :git的使用

    项目管理离不开版本控制,目前主流版本控制工具大概就是SVN和Git,至于两者有啥区别这里就不详细介绍了,如果有不明白的可以上网查资料,后期如果有机会我再开篇栏目细说,而且现在市场上Git的使用率已经远 ...

  4. eclipse快捷注释生成方法

    自动生成方法的注释格式,例如 /*** @param str* @return* @throws ParseException*/ 快捷键是alt+shift+j,将光标放在方法名上,按快捷键.会生成 ...

  5. PHP中单引号与双引号的区别

    在PHP中,字符串的定义可以使用英文单引号' ',也可以使用英文双引号" ". 一般情况下两者是通用的.但双引号内部变量会解析,单引号则不解析. PHP允许我们在双引号串中直接包含 ...

  6. Ubuntu14.04+Nginx+MySql+PHP环境配置

    http://www.cnblogs.com/gophper/p/4793711.html

  7. markdown学习经验

    文章首发于我的github博客 前言 markdown是一种简洁有力的文本编辑语言.由于它十分好用,我将所有的博客都换成了markdown编辑器. 学习方法 工具为先,从工具中学习,熟能生巧. 工具选 ...

  8. Ceph神坑系列

    1. 在使用librbd的过程中,发现一个如果ceph集群异常librbd函数不返回的问题,对librbd的源码进行跟踪,发现了rados接口中的rados_mon_op_timeout(how ma ...

  9. MySQL SQL语句分析查询优化

    如何获取有性能问题的SQL 1.通过用户反馈获取存在性能问题的SQL 2.通过慢查询日志获取性能问题的SQL 3.实时获取存在性能问题的SQL 使用慢查询日志获取有性能问题的SQL 首先介绍下慢查询相 ...

  10. hbase 命令

    HBase是Google Bigtable的开源实现,它利用Hadoop HDFS作为其文件存储系统,利用Hadoop MapReduce来处理HBase中的海量数据,利用Zookeeper作为协同服 ...