题目

luogu

原来左偏树真的能懒惰下放

这篇博客应该要咕咕了

一开始我按照那篇博客想了一下,感觉emm,还是瞄了一眼看到了pushdown

思路

类似线段树2的pushdown,不过是套在了左偏树

其他也就没啥了

ans1直接删除统计

ans2就初始深度-死亡深度(树的路径唯一嘛)

ps:深度可以在dfs的时候顺便求出来

就这样

错误&&反思

一开始20,死活不对

最后又是手贱n写成m

还是20

又经过漫长debug(不会造树data的伤感)

无奈去看题解,长着差不多的模样

最后

 while(val[rt[u]] < fangyu[u] && rt[u]) {
pushdown(rt[u]);
ans2[rt[u]]=dep[S[rt[u]]]-dep[u];
ans1[u]++;
rt[u]=merge(ch[rt[u]][0],ch[rt[u]][1]);
}

居然一个pushdown就OK了

我想着是merge就会pushdown的,就没写、、、、

代码

#include <iostream>
#include <cstdio>
#define FOR(i,a,b) for(int i=a;i<=b;++i)
using namespace std;
const int maxn=3e5+7;
typedef long long ll;
inline ll read() {
ll x=0,f=1;char s=getchar();
for(;s<'0'||s>'9';s=getchar()) if(s=='-') f=-1;
for(;s>='0'&&s<='9';s=getchar()) x=x*10+s-'0';
return x*f;
}
struct node {
int v,nxt;
}e[maxn];
int head[maxn],tot;
void add_edge(int u,int v) {
e[++tot].v=v;
e[tot].nxt=head[u];
head[u]=tot;
}
int n,m,cnt,rt[maxn],ch[maxn][2],dis[maxn],ans1[maxn],ans2[maxn],dep[maxn];
ll A[maxn],B[maxn],fangyu[maxn],ad[maxn],mu[maxn],val[maxn];
void da_tag(int x,ll a,ll b) {
val[x]=val[x]*a+b;
ad[x]=ad[x]*a+b;
mu[x]*=a;
}
void pushdown(int x) {
if(ad[x]==0&&mu[x]==1) return;
int it_a=ch[x][0],it_b=ch[x][1];
da_tag(it_a,mu[x],ad[x]);
da_tag(it_b,mu[x],ad[x]);
ad[x]=0,mu[x]=1;
}
int merge(int x,int y) {
if(!x || !y) return x+y;
pushdown(x),pushdown(y);
if(val[x]>val[y]) swap(x,y);
ch[x][1]=merge(ch[x][1],y);
if(dis[ch[x][0]]<dis[ch[x][1]]) swap(ch[x][0],ch[x][1]);
dis[x]=dis[ch[x][1]]+1;
return x;
}
int S[maxn];
int dfs(int u,int f) {
dep[u]=dep[f]+1;
for(int i=head[u];i;i=e[i].nxt) {
int tmp=dfs(e[i].v,u);
rt[u]=merge(rt[u],tmp);
}
while(val[rt[u]] < fangyu[u] && rt[u]) {
pushdown(rt[u]);
ans2[rt[u]]=u;
ans1[u]++;
rt[u]=merge(ch[rt[u]][0],ch[rt[u]][1]);
}
da_tag(rt[u],A[u],B[u]);
return rt[u];
}
int main() {
n=read(),m=read();
FOR(i,1,m) mu[i]=1;
FOR(i,1,n) fangyu[i]=read();
FOR(i,2,n) {
int x=read(),y=read();
add_edge(x,i);
A[i]=1;
if(y) A[i]=read();
else B[i]=read();
}
FOR(i,1,m) {
ll x=read();S[i]=read();
val[i]=x;
rt[S[i]]=merge(rt[S[i]],i);
}
dfs(1,0);
FOR(i,1,n) cout<<ans1[i]<<"\n";
FOR(i,1,m) cout<<dep[S[i]]-dep[ans2[i]]<<"\n";
return 0;
}

luogu3261 懒惰左偏树 [JLOI2015]城池攻占的更多相关文章

  1. [luogu3261 JLOI2015] 城池攻占 (左偏树+标记)

    传送门 Description 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池.这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的 ...

  2. 【BZOJ4003】【JLOI2015】城池攻占(左偏树)

    题面 题目描述 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池.这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的管辖,其中 fi ...

  3. [JLOI2015]城池攻占 左偏树

    题目描述 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池.这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的管辖,其中 fi &l ...

  4. 【左偏树】【P3261】 [JLOI2015]城池攻占

    Description 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池.这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的管辖,其 ...

  5. [洛谷P3261] [JLOI2015]城池攻占(左偏树)

    不得不说,这道题目是真的难,真不愧它的“省选/NOI-”的紫色大火题!!! 花了我晚自习前半节课看题解,写代码,又花了我半节晚自习调代码,真的心态爆炸.基本上改得和题解完全一样了我才过了这道题!真的烦 ...

  6. P3261 [JLOI2015]城池攻占 (左偏树+标记下传)

    左偏树还是满足堆的性质,节点距离就是离最近的外节点(无左或者右儿子  或者二者都没有)的距离,左偏性质就是一个节点左儿子的距离不小于右儿子,由此得:节点距离等于右儿子的距离+1. 本题就是对于每个节点 ...

  7. BZOJ 4003: [JLOI2015]城池攻占 左偏树 可并堆

    https://www.lydsy.com/JudgeOnline/problem.php?id=4003 感觉就是……普通的堆啊(暴论),因为这个堆是通过递归往右堆里加一个新堆或者新节点的,所以要始 ...

  8. BZOJ 4003 / Luogu P3261 [JLOI2015]城池攻占 (左偏树)

    左偏树裸题,在树上合并儿子传上来的堆,然后小于当前结点防御值的就pop掉,pop的时候统计答案. 修改的话就像平衡树一样打懒标记就行了. 具体见代码 CODE #include<bits/std ...

  9. 【左偏树】 [JLOI2015]城池攻占

    原来左偏树还可以打tag,get了 和线段树打tag一样,时不时Push_Down就好了 然后这里显然也是要先乘法后加法的 tag打上了之后还是其他一般左偏树差不多,有些细节注意一下 然后开 long ...

随机推荐

  1. MYSQL 命令行显示乱码 解决方案

    中文乱码是因为编码集不支持,所以要改变编码 先查看下设置的编码 使用如下命令 show variables like 'character%'; 在 mysql.conf (Ubuntu mysql5 ...

  2. struts2 错误:Dispatcher initialization failed java.lang.RuntimeException

    严重: Dispatcher initialization failed java.lang.RuntimeException: java.lang.reflect.InvocationTargetE ...

  3. 帝国cms底部代码哪里改?要修改版权和统计代码

    最近接手的几个站是用帝国cms做的,底部代码那边都有一个**设计的链接,还有一些不相关的东西,第一眼看到就想把那些帝国cms底部代码清理掉,这就是让别人建站的烦恼,让他们删除说要收费,坑就一个字,自己 ...

  4. android 操作SD卡上的文件

    (1)说明:操作SD卡上的文件须要增加下面权限  在SD卡上创建和删除文件权限  <uses-permission android:name="android.permission.M ...

  5. Python绘图工具matplotlib的使用(图形并茂)

    matplotlib官网文档: http://matplotlib.org/gallery.html 支持win7_64_bit的matplotlib库下载网址: http://www.lfd.uci ...

  6. 查询mysql事务隔离级别

    查询mysql事务隔离级别 查询mysql事务隔离级别 分类: DB2011-11-26 13:12 2517人阅读 评论(0) 收藏 举报 mysqlsessionjava   1.查看当前会话隔离 ...

  7. MySQL DBA 管理常用命令

    一:在Linux下管理MySQL数据库的时候总有一些很紧急的情况,发现数据库突然变得压力很大了,那么作为一个DBA,也许需要一些常用的手段或者说命令去分析问题出现在哪里,然后解决: 数据库突然产生压力 ...

  8. 009-java中常用的单个键值对

    1.Java 6提供AbstractMap.SimpleEntry<K,V>和AbstractMap.SimpleImmutableEntry<K,V> Map.Entry&l ...

  9. 开源的挖矿软件,sha256

    http://cryptomining-blog.com/tag/sha-256d-miner/ https://github.com/cbuchner1/CudaMiner/blob/master/ ...

  10. SQLAlchemy通过models创建数据库表

    原地址:http://blog.csdn.net/jmilk/article/details/53184903 定义数据模型 models SQLAlchemy 允许我们根据数据库的表结构来创建数据模 ...