[POI2011]MET-Meteors 整体二分_树状数组_卡常
线段树肯定会 TLE 的,必须要用树状数组.
Code:
// luogu-judger-enable-o2
#include <cstdio>
#include <algorithm>
#include <vector>
#include <cstring>
#include <cctype>
#define setIO(s) freopen(s".in","r",stdin)
#define maxn 300009
#define ll long long
using namespace std;
vector<int>G[maxn];
int n,m,k,cnt[maxn],left[maxn<<1],right[maxn<<1],que[maxn],result[maxn];
int tl[maxn],tr[maxn];
int current[maxn],cost[maxn],w[maxn<<1];
inline int read()
{
int k=0,f=1;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-')f=-1;
for(;isdigit(c);c=getchar()) k=k*10+c-'0';return f*k;
}
struct Segment_Tree{
ll sumv[maxn<<2],lazy[maxn<<2];
#define lson (o<<1)
#define rson (o<<1)|1
void mark(int l,int r,int o,int delta)
{
sumv[o]+=delta*(r-l+1);
lazy[o]+=delta;
}
int lowbit(int x){ return x&(-x); }
void update(int l,int r,int L,int R,int o,int k){
while(L<=r) sumv[L]+=k,L+=lowbit(L);
++R;
while(R<=r) sumv[R]-=k,R+=lowbit(R);
}
ll query(int l,int r,int pos,int pos2,int o){
ll sum=0;
while(pos>0) sum+=sumv[pos],pos-=lowbit(pos);
return sum;
}
}tree;
void solve(int x,int y,int l,int r){
if(x>y||l>r) return;
if(l==r){
for(int i=x;i<=y;++i) result[que[i]]=l;
return;
}
int mid=(l+r)>>1,p=0,q=0,qcnt;
ll s;
for(int i=l;i<=mid;++i) {
for(int cur=cnt[i-1]+1;cur<=cnt[i];++cur) {
tree.update(1,m,left[cur],right[cur],1,w[cur]);
}
}
for(int i=x;i<=y;++i){
int u=que[i];
int siz=G[u].size();
s=current[u];
for(int j=0;j<siz&&s<=(ll)cost[u];++j)
s+=tree.query(1,m,G[u][j],G[u][j],1);
if(s>=cost[u]) tl[++p]=u;
else tr[++q]=u,current[u]=s;
}
for(int i=l;i<=mid;++i)
for(int cur=cnt[i-1]+1;cur<=cnt[i];++cur)
tree.update(1,m,left[cur],right[cur],1,-w[cur]);
qcnt=x-1;
for(int i=1;i<=p;++i) que[++qcnt]=tl[i];
for(int i=1;i<=q;++i) que[++qcnt]=tr[i];
solve(x,x+p-1,l,mid),solve(x+p,y,mid+1,r);
}
int main(){
//setIO("input");
n=read(),m=read();
for(int i=1;i<=m;++i)
{
int a=read();
G[a].push_back(i);
}
for(int i=1;i<=n;++i) cost[i]=read();
k=read();
int idx=0;
for(int i=1;i<=k;++i){
int l,r,c;
l=read(),r=read(),c=read();
if(l<=r) cnt[i]=++idx,left[idx]=l,right[idx]=r,w[idx]=c;
else {
cnt[i]=++idx;
left[idx]=l,right[idx]=m,w[idx]=c;
cnt[i]=++idx;
left[idx]=1,right[idx]=r,w[idx]=c;
}
}
for(int i=1;i<=n;++i) que[i]=i;
cnt[++k]=++idx;
left[idx]=1,right[idx]=m,w[idx]=(int)1e9;
solve(1,n,1,k);
for(int i=1;i<=n;++i)
if(result[i]==k) printf("NIE\n");
else printf("%d\n",result[i]);
return 0;
}
[POI2011]MET-Meteors 整体二分_树状数组_卡常的更多相关文章
- Luogu3527 POI2011 Meteors 整体二分、树状数组、差分
传送门 比较板子的整体二分题目,时限有点紧注意常数 整体二分的过程中将时间在\([l,mid]\)之间的流星使用树状数组+差分进行维护,然后对所有国家查看一遍并分好类,递归下去,记得消除答案在\([m ...
- 【BZOJ4009】[HNOI2015]接水果 DFS序+整体二分+扫描线+树状数组
[BZOJ4009][HNOI2015]接水果 Description 风见幽香非常喜欢玩一个叫做 osu!的游戏,其中她最喜欢玩的模式就是接水果.由于她已经DT FC 了The big black, ...
- BZOJ 4009: [HNOI2015]接水果 (整体二分+扫描线 树状数组)
整体二分+扫描线 树状数组 具体做法看这里a CODE #include <cctype> #include <cstdio> #include <cstring> ...
- bzoj4009 [HNOI2015]接水果 整体二分+扫描线+树状数组+dfs序
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4009 题解 考虑怎样的情况就会有一个链覆盖另一个链. 设被覆盖的链为 \(a - b\),覆盖 ...
- [bzoj3529][Sdoi2014]数表_树状数组_莫比乌斯反演
数表 bzoj-3529 Sdoi-2014 题目大意:n*m的数表,第i行第j列的数是同时整除i和j的所有自然数之和.给定a,求数表中所有不超过a的和. 注释:$1\le n,m \le 10^5$ ...
- [bzoj3192][JLOI2013]删除物品_树状数组_栈
删除物品 bzoj-3192 JLOI-2013 题目大意:给你n个物品,分成2堆.所有的物品有不同的优先级.我只可以将一堆中的堆顶移动到另一个堆的堆顶.而如果当前物品是全局所有物品中优先级最高的,我 ...
- [Cometoj#4 E]公共子序列_贪心_树状数组_动态规划
公共子序列 题目链接:https://cometoj.com/contest/39/problem/E?problem_id=1585 数据范围:略. 题解: 首先可以考虑知道了$1$的个数和$3$的 ...
- nyoj123_士兵杀敌(四)_树状数组_插线求点
士兵杀敌(四) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战 ...
- BZOJ_5055_膜法师_树状数组+离散化
BZOJ_5055_膜法师_树状数组+离散化 Description 在经历过1e9次大型战争后的宇宙中现在还剩下n个完美维度, 现在来自多元宇宙的膜法师,想偷取其中的三个维度为伟大的长者续秒, 显然 ...
随机推荐
- 上传文件时文件类型限制 <input id="File1" type="file" accept=""/>
在做项目项目中经常需要上传文件,类型也就那几种.虽然在js中加了上传文件类型的限制,但是为了减少因为用户选择不当而造成的反复检验.可以在input标签上加上accept属性.这种限制只是优化了选择文件 ...
- JQuery中的find、filter和each方法学习
find() 概述 搜索所有与指定表达式匹配的元素.这个函数是找出正在处理的元素的后代元素的好方法. 所有搜索都依靠jQuery表达式来完成.这个表达式可以使用CSS1-3的选择器语法来写. 参数 e ...
- 你不知道的JavaScript(六)Box&Unbox
很多语言中都有Box和Unbox的概念,很多书籍把Box翻译为"装箱操作",指的是將基本数据类型包装成对象:Unbox和它相反,把对象类型转换为基本类型. 我们知道JavaScri ...
- JavaScript学习——使用JS完成省市二级联动
1.我们希望在注册页面中添加一个字段(籍贯),当用户选择一个具体的省份,在后面的下拉列表中动态加载该省份下所有的城市.显示的效果如下: 2.步骤分析: 第一步:确定事件(onchange)并为其绑定一 ...
- Java数据库连接——jdbc-odbc桥连接方式及汉字乱码问题
jdbc-odbc桥连接方式操作数据库SU(Course),其中Course属性有Cno,Cname,Cpno,Ccredit. 步骤: 1.配置数据源 控制面板下搜索管理工具->ODBC数据源 ...
- 利用IP安全策略关闭危险端口
默认情况下,Windows服务器有很多端口是开放的,网络病毒和黑客可以通过这些端口连上你的服务器并进行攻击. 为了让你的系统变为铜墙铁壁,应该封闭这些端口,主要有:TCP 135.139.445.59 ...
- STM8S103之ADC
如何快速了解ADC,查看Reference manual中ADC registers章节,初步了解到ADC ADC buffer register和ADC data register Analog W ...
- Jlink如何校验Hex
打开SEGGER J-Flash ARM,记住必须设置好工程属性后才能校验,否则校验和为0 设置好工程属性后,直接将Hex拖入到工程中即可.在LOG窗口中会显示CRC的值 如何校验芯片中的程序的版本号 ...
- UVa 10801 Lift Hopping【floyd 】
题意:给出n个电梯,每个电梯的运行时间,每个电梯只能在相应的楼层停靠,而且没有楼梯,再给出想去的楼层,问从0层能否到达想去的楼层,求到达的最短时间 建图还是没有建出来--- 因为n<100,可以 ...
- Python学习笔记(二):字符串类型
在上一篇随笔(https://www.cnblogs.com/g-qiang/p/10448813.html)中,说到 Python 有六种标准数据类型,而数字类型和字符串类型又是其中基本的数据类型. ...