线段树肯定会 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 整体二分_树状数组_卡常的更多相关文章

  1. Luogu3527 POI2011 Meteors 整体二分、树状数组、差分

    传送门 比较板子的整体二分题目,时限有点紧注意常数 整体二分的过程中将时间在\([l,mid]\)之间的流星使用树状数组+差分进行维护,然后对所有国家查看一遍并分好类,递归下去,记得消除答案在\([m ...

  2. 【BZOJ4009】[HNOI2015]接水果 DFS序+整体二分+扫描线+树状数组

    [BZOJ4009][HNOI2015]接水果 Description 风见幽香非常喜欢玩一个叫做 osu!的游戏,其中她最喜欢玩的模式就是接水果.由于她已经DT FC 了The big black, ...

  3. BZOJ 4009: [HNOI2015]接水果 (整体二分+扫描线 树状数组)

    整体二分+扫描线 树状数组 具体做法看这里a CODE #include <cctype> #include <cstdio> #include <cstring> ...

  4. bzoj4009 [HNOI2015]接水果 整体二分+扫描线+树状数组+dfs序

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4009 题解 考虑怎样的情况就会有一个链覆盖另一个链. 设被覆盖的链为 \(a - b\),覆盖 ...

  5. [bzoj3529][Sdoi2014]数表_树状数组_莫比乌斯反演

    数表 bzoj-3529 Sdoi-2014 题目大意:n*m的数表,第i行第j列的数是同时整除i和j的所有自然数之和.给定a,求数表中所有不超过a的和. 注释:$1\le n,m \le 10^5$ ...

  6. [bzoj3192][JLOI2013]删除物品_树状数组_栈

    删除物品 bzoj-3192 JLOI-2013 题目大意:给你n个物品,分成2堆.所有的物品有不同的优先级.我只可以将一堆中的堆顶移动到另一个堆的堆顶.而如果当前物品是全局所有物品中优先级最高的,我 ...

  7. [Cometoj#4 E]公共子序列_贪心_树状数组_动态规划

    公共子序列 题目链接:https://cometoj.com/contest/39/problem/E?problem_id=1585 数据范围:略. 题解: 首先可以考虑知道了$1$的个数和$3$的 ...

  8. nyoj123_士兵杀敌(四)_树状数组_插线求点

    士兵杀敌(四) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5   描述 南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战 ...

  9. BZOJ_5055_膜法师_树状数组+离散化

    BZOJ_5055_膜法师_树状数组+离散化 Description 在经历过1e9次大型战争后的宇宙中现在还剩下n个完美维度, 现在来自多元宇宙的膜法师,想偷取其中的三个维度为伟大的长者续秒, 显然 ...

随机推荐

  1. nyoj--325--zb的生日(简单dp)

    zb的生日 时间限制:3000 ms  |  内存限制:65535 KB 难度:2 描述 今天是阴历七月初五,acm队员zb的生日.zb正在和C小加.never在武汉集训.他想给这两位兄弟买点什么庆祝 ...

  2. hexo博客谷歌百度收录踩坑日记

    title: hexo博客谷歌百度收录踩坑日记 toc: false date: 2018-04-17 00:09:38 百度收录文件验证 无论怎么把渲染关掉或者render_skip都说我的格式错误 ...

  3. SQLServer 错误: 15404,维护计划无法执行

    错误症状: D:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\LOG下面的ERROELOG,用文本打,查看运行维维计划不成功是生成的错误日志详细信 ...

  4. 一个渣渣python脚本,用wol控制开机

    #!/usr/bin/env python #coding:utf8 import os,time d={} '''f = open('E:\info.txt','r') for ipmac in f ...

  5. (noip模拟十七)【BZOJ3930】[CQOI2015]选数-容斥水法

    Description 我们知道,从区间[L,H](L和H为整数)中选取N个整数,总共有(H-L+1)^N种方案.小z很好奇这样选出的数的最大公约数的规律,他决定对每种方案选出的N个整数都求一次最大公 ...

  6. 支持JSONP跨域的对象

    支持JSONP跨域的对象 1:img 2:iframe 3:link 4:script 为什么,JSONP 最终选择是 script 实现呢?度娘来也! 平常我们进行JSONP请求数据,因为 json ...

  7. git 常用操作命令行

    mkdir files : 创建一个名字为files的文件夹 cd files : 切换目录到files pwd ; 显示当前所在目录 ls -ah : 查看本地隐藏不可见的文件夹 git init ...

  8. 物理机安装CentOS7

    最近捯饬到一台很老的机器,装Win7吧卡的不要不要的,思来想去的,搞个CentOS来玩玩,玩玩python的一些个人项目,一般装机啥的,都要做启动盘啥的,但是,这个都的话有很多网友已经分享了很多好的文 ...

  9. thinkphp 5.0整合phpsocketio完整攻略,绕坑

    使用环境: thinkphp5.0 项目需求 前端下单,后台接受,并立即做出提示.例如:美团外卖,客户端下单成功后,商家端就会立即有接单语音提示. 开发环境 thinkphp5.0 phpsocket ...

  10. 紫书 例题8-15 UVa 12174 (滑动窗口)

    这道题就是给你一n长序列, 然后把这个序列按顺序分成很多段, 每段长s(最前面可以小于s, 只有第一段的后半段, 最后面也同样, 只有最后一段的前半段), 然后要求是每一段里面没有重复的数, 问你有几 ...