【BZOJ2527】MET-Meteors(整体二分)
【BZOJ2527】MET-Meteors(整体二分)
题面
题解
其实我也不会做
看了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(整体二分)的更多相关文章
- 【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——整体二分+树状数组
题目描述 Byteotian Interstellar Union (BIU) has recently discovered a new planet in a nearby galaxy. The ...
- BZOJ2527: [Poi2011]Meteors(整体二分)
Description Byteotian Interstellar Union (BIU) has recently discovered a new planet in a nearby gala ...
- 【BZOJ2527】[Poi2011]Meteors 整体二分
[BZOJ2527][Poi2011]Meteors Description Byteotian Interstellar Union (BIU) has recently discovered a ...
- 【BZOJ2527】【POI2011】Meteors [整体二分]
Meteors Time Limit: 60 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description 这个星球经常会下陨石雨.BI ...
- 【bzoj2527】[Poi2011]Meteors 整体二分+树状数组
题目描述 有N个成员国.现在它发现了一颗新的星球,这颗星球的轨道被分为M份(第M份和第1份相邻),第i份上有第Ai个国家的太空站. 这个星球经常会下陨石雨.BIU已经预测了接下来K场陨石雨的情况.BI ...
- [bzoj2527][Poi2011]Meteors_整体二分_树状数组
Meteors bzoj-2527 Poi-2011 题目大意:题目链接. 注释:略. 想法: 首先答案可以离线,且具有单调性. 这里的单调性就是随着时间的推移,每个国家收集的陨石数增加. 不难想到整 ...
- bzoj 2527 Meteors - 整体二分 - 树状数组
Description Byteotian Interstellar Union (BIU) has recently discovered a new planet in a nearby gala ...
- 2527: [Poi2011]Meteors[整体二分]
2527: [Poi2011]Meteors Time Limit: 60 Sec Memory Limit: 128 MB Submit: 1528 Solved: 556 [Submit][S ...
随机推荐
- php环境搭建和第一个php程序
一.开发环境搭建 因为是初学,使用的还是非常经典的组合appserv+dreamweaver cs6; 1.1 appserv安装 appserv的安装还是非常简单的,直接双击可执行程序appse ...
- WEB-INF目录下文件复制的几种方式
2018年1月31日 10:42:55 工作完写点博客记录下. 需求:从web-inf下拷贝文件到指定目录. 目录结构 直接贴代码 第一种方式,字节流读取 try { int index = 0; S ...
- 深入理解vue
一 理解vue的核心理念 使用vue会让人感到身心愉悦,它同时具备angular和react的优点,轻量级,api简单,文档齐全,简单强大,麻雀虽小五脏俱全. 倘若用一句话来概括vue,那么我首先想到 ...
- MySQL事务处理案例演示
<?php $mysqli=new mysqli("localhost", "root", "123456", "xsphp ...
- Redis 实践3-操作
string常用操作 set key1 aminglinux get key1 set key1 aming //一个key对应一个value,多次赋值,会覆盖前面的value setnx k ...
- appium+Python 启动app(二)
我们上步操作基本完成,下面介绍编写Python脚本启动app 打开我们pycharm新建.py文件 第一步:输入Python脚本代码: #coding=utf-8 from appium import ...
- C++ 11 左值,右值,左值引用,右值引用,std::move, std::foward
这篇文章要介绍的内容和标题一致,关于C++ 11中的这几个特性网上介绍的文章很多,看了一些之后想把几个比较关键的点总结记录一下,文章比较长.给出了很多代码示例,都是编译运行测试过的,希望能用这些帮助理 ...
- 由select引发的思考
一.前言 网络编程里一个经典的问题,selec,poll和epoll的区别?这个问题刚学习编程时就接触了,当时看了材料很不明白,许多概念和思想没有体会,现在在这个阶段,再重新回头看这个问题,有一种豁然 ...
- hihoCoder 1523 数组重排2 贪心
题意:给定一个1-N的排列A1, A2, - AN,每次操作小Hi可以选择一个数,把它放到数组的最左边. 请计算小Hi最少进行几次操作就能使得新数组是递增排列的. 思路:最后的序列是递增的,那么必定满 ...
- scrapy 中日志的使用
我在后台调试 在后台调试scrapy spider的时候,总是觉得后台命令窗口 打印的东西太多了不便于观察日志,因此需要一个日志文件记录信息,这样以后会 方便查找问题. 分两种方法吧. 1.简单粗暴. ...