luogu3261 懒惰左偏树 [JLOI2015]城池攻占
题目
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]城池攻占的更多相关文章
- [luogu3261 JLOI2015] 城池攻占 (左偏树+标记)
传送门 Description 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池.这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的 ...
- 【BZOJ4003】【JLOI2015】城池攻占(左偏树)
题面 题目描述 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池.这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的管辖,其中 fi ...
- [JLOI2015]城池攻占 左偏树
题目描述 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池.这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的管辖,其中 fi &l ...
- 【左偏树】【P3261】 [JLOI2015]城池攻占
Description 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池.这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的管辖,其 ...
- [洛谷P3261] [JLOI2015]城池攻占(左偏树)
不得不说,这道题目是真的难,真不愧它的“省选/NOI-”的紫色大火题!!! 花了我晚自习前半节课看题解,写代码,又花了我半节晚自习调代码,真的心态爆炸.基本上改得和题解完全一样了我才过了这道题!真的烦 ...
- P3261 [JLOI2015]城池攻占 (左偏树+标记下传)
左偏树还是满足堆的性质,节点距离就是离最近的外节点(无左或者右儿子 或者二者都没有)的距离,左偏性质就是一个节点左儿子的距离不小于右儿子,由此得:节点距离等于右儿子的距离+1. 本题就是对于每个节点 ...
- BZOJ 4003: [JLOI2015]城池攻占 左偏树 可并堆
https://www.lydsy.com/JudgeOnline/problem.php?id=4003 感觉就是……普通的堆啊(暴论),因为这个堆是通过递归往右堆里加一个新堆或者新节点的,所以要始 ...
- BZOJ 4003 / Luogu P3261 [JLOI2015]城池攻占 (左偏树)
左偏树裸题,在树上合并儿子传上来的堆,然后小于当前结点防御值的就pop掉,pop的时候统计答案. 修改的话就像平衡树一样打懒标记就行了. 具体见代码 CODE #include<bits/std ...
- 【左偏树】 [JLOI2015]城池攻占
原来左偏树还可以打tag,get了 和线段树打tag一样,时不时Push_Down就好了 然后这里显然也是要先乘法后加法的 tag打上了之后还是其他一般左偏树差不多,有些细节注意一下 然后开 long ...
随机推荐
- 【Git 使用笔记】第三部分:多分支开发
###举例仓库 仓库地址A:git@gitlab.54php.cn:guowei/demos.git 仓库地址B:git@gitlab.54php.cn:infra/demos.git 开发人员仓库C ...
- 删除未加入svn版本控制的文件(包括文件夹)
删除未加入svn版本控制的文件(包括文件夹) svn status | grep '^?' | awk '{print $2}' | xargs rm -rf
- 2018/04/16 PHP 设计模式之工厂模式
学习设计模式一定要知道它是为了什么而产生的,凡事一定有原因. 站在巨人的肩膀上学习,推荐两篇文章 什么是php工厂模式?为何要用php工厂模式? php工厂模式的使用实例总结 PHP设计模式之工厂模式 ...
- (1.2)mysql 索引概念
索引的存储分类:mysql目前提供了以下4种索引 [1]B-Tree索引:最常见的索引类型,大部分引擎都支持B树索引 [2]HASH索引:只有Memory引擎支持,使用场景简单 [3]R-Tree索引 ...
- ifconfig 查看网卡信息
[root@linux-node- sss]# ifconfig eno16777736: flags=<UP,BROADCAST,RUNNING,MULTICAST> mtu inet ...
- Linuxer-"Linux开发人员自己的媒体"第五月稿件和赠书名单
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/juS3Ve/article/details/78859630 Linuxer已经从一个单纯的读者服务 ...
- win10 问题:你没有权限在此位置中保存文件。请与管理员联系以获得相应权限。
https://jingyan.baidu.com/album/b24f6c8207f09886bee5da4a.html?picindex=2 归根结底就是通过点击文件夹的属性,在安全选项处,修改操 ...
- 【Flask】关于Flask的request属性
前言 在进行Flask开发中,前端需要发送不同的请求及各种带参数的方式,比如GET方法在URL后面带参数和POST在BODY带参数,有时候又是POST的表单提交方式,这个时候就需要从request提取 ...
- Linux CentOS6.5下编译安装MySQL 5.6
检查:卸载掉原有MySql 因为mysql数据库在Linux上实在是太流行了,所以目前下载的主流Linux系统版本基本上都集成了mysql数据库在里面,我们可以通过如下命令来查看我们的操作系统上是否已 ...
- soft nofile
原创文章,转载请注明出处:http://jameswxx.iteye.com/blog/2096461 写这个文章是为了以正视听,网上的文章人云亦云到简直令人发指.到底最大文件数被什么限制了?too ...