[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个完美维度, 现在来自多元宇宙的膜法师,想偷取其中的三个维度为伟大的长者续秒, 显然 ...
随机推荐
- CoreData 从入门到精通(四)并发操作
通常情况下,CoreData 的增删改查操作都在主线程上执行,那么对数据库的操作就会影响到 UI 操作,这在操作的数据量比较小的时候,执行的速度很快,我们也不会察觉到对 UI 的影响,但是当数据量特别 ...
- 5分钟学会 CSS Grid 布局
欢迎加入前端交流群交流知识&&获取视频资料:749539640 这是一篇快速介绍网站未来布局的文章. Grid 布局是网站设计的基础,CSS Grid 是创建网格布局最强大和最简单的工 ...
- POJ 3213 矩阵乘法(优化)
思路: 1.暴力出奇迹 n=1000 n^3矩阵乘法竟然能卡过...(Tips:不要乱写读入优化,这玩意儿加了超时,不加AC--) 2. 注意题目中的"最多只能有一个地方不一样,," ...
- CBO基础概念
CBO基础概念 CBO:评估 I/O,CPU,网络(DBLINK)等消耗的资源成本得出 一.cardinality cardinality:集合中包含的记录数.实际CBO评估目标SQL执行具体步骤的记 ...
- [转帖]关于Xilinx下Micro_Blaze中UartLite232外设的使用
来源:https://blog.csdn.net/shen_you/article/details/78713746
- 1、Windows服务器 VS Linux服务器
- SQL Server查询死锁,杀死进程解决死锁
查询死锁进程和表 SELECT request_session_id AS spid , OBJECT_NAME(resource_associated_entity_id) AS 'table' F ...
- java开发过程中几种常用算法
排序算法 排序算法中包括:简单排序.高级排序 简单排序 简单排序常用的有:冒泡排序.选择排序.插入排序 冒泡排序代码如下: private static void bubbleSrot(int[] a ...
- MFC基础知识
1.句柄:具有内存后,系统返回的标识符 2.消息:相当于事件,例如鼠标点击就是一个消息 3.消息队列:就是将事件按照时间的先后顺序在一个队列中 4.消息处理机制:首先操作系统拿到消息,然后将消息放到消 ...
- luogu P4430 小猴打架(prufer编码与Cayley定理)
题意 n个点问有多少种有顺序的连接方法把这些点连成一棵树. (n<=106) 题解 了解有关prufer编码与Cayley定理的知识. 可知带标号的无根树有nn-2种.然后n-1条边有(n-1) ...