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

本题就是对于每个节点都建立一颗左偏树(小根堆),存的是在当前节点的骑士,从下往上模拟题意就行了。

 1 #include <bits/stdc++.h>
2 using namespace std;
3 #define ll long long
4 const int N = 3e5 + 10;
5 int n, m;
6 int fa[N], c[N], a[N], rt[N];
7 ll h[N], v[N], s[N];
8 int ls[N], rs[N], dep[N];
9 int Dep[N], die[N], ans[N];
10 ll add[N], tim[N];//+ *
11
12 void pushdown(int x) {//下传标记
13 if (add[x] == 0 && tim[x] == 1) return;
14 if (ls[x]) {
15 tim[ls[x]] *= tim[x];
16 add[ls[x]] *= tim[x];
17 add[ls[x]] += add[x];
18 s[ls[x]] *= tim[x];
19 s[ls[x]] += add[x];
20 }//先处理乘再处理加
21 if (rs[x]) {
22 tim[rs[x]] *= tim[x];
23 add[rs[x]] *= tim[x];
24 add[rs[x]] += add[x];
25 s[rs[x]] *= tim[x];
26 s[rs[x]] += add[x];
27 }
28 add[x] = 0, tim[x] = 1; //恢复标记
29 }
30
31 int merge(int x, int y) {
32 if (!x || !y) return x + y;
33 pushdown(x), pushdown(y);
34 if (s[x] > s[y]) swap(x, y);//小根堆
35 rs[x] = merge(rs[x], y);//x的右节点与y合并
36 if (dep[ls[x]] < dep[rs[x]]) swap(ls[x], rs[x]);//维护左偏性质
37 dep[x] = dep[rs[x]] + 1;
38 return x;
39 }
40
41 int main() {
42 scanf("%d %d", &n, &m);
43 for (int i = 1; i <= n; i++) {
44 scanf("%lld", &h[i]);//城池防御力
45 rt[i] = -1;//设为空
46 }
47 Dep[1] = 1, dep[0] = -1;
48 for (int i = 2; i <= n; i++) {
49 scanf("%d %d %lld", &fa[i], &a[i], &v[i]);//父亲 城池能力改变方式 城池能力改变值
50 Dep[i] = Dep[fa[i]] + 1;
51 }
52 for (int i = 1; i <= m; i++) {
53 scanf("%lld %d", &s[i], &c[i]);//骑士能力 出生地
54 tim[i] = 1;
55 if (rt[c[i]] == -1) rt[c[i]] = i;
56 else rt[c[i]] = merge(rt[c[i]], i);//合并同城骑士
57 }
58 for (int i = n; i >= 1; i--) {//从下到上
59 while (rt[i] != -1) {//当前堆不为空
60 if (s[rt[i]] < h[i]) {
61 die[rt[i]] = i;//死亡
62 pushdown(rt[i]);
63 if (!ls[rt[i]]) rt[i] = -1;
64 else rt[i] = merge(ls[rt[i]], rs[rt[i]]);
65 }
66 else break;//剩下的不死
67 }
68 if (i == 1) break;//特判根节点
69 if (rt[i] == -1) continue;
70 if (a[i]) tim[rt[i]] *= v[i], add[rt[i]] *= v[i], s[rt[i]] *= v[i];
71 else add[rt[i]] += v[i], s[rt[i]] += v[i];
72 pushdown(rt[i]);
73 if (rt[fa[i]] == -1) rt[fa[i]] = rt[i];
74 else rt[fa[i]] = merge(rt[fa[i]], rt[i]);//幸存骑士到父节点
75 }
76 for (int i = 1; i <= m; i++) ans[die[i]]++;
77 for (int i = 1; i <= n; i++) printf("%d\n", ans[i]);
78 for (int i = 1; i <= m; i++) printf("%d\n", Dep[c[i]] - Dep[die[i]]);
79 return 0;
80 }
81 /*
82 1.注意tim 初始化为1
83 2.dep[0] = -1 ***** 左偏树中空节点距离要设为-1
84 3.注意处理标记
85 4.特判骑士死光的情况(MLE)
86 */

P3261 [JLOI2015]城池攻占 (左偏树+标记下传)的更多相关文章

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

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

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

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

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

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

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

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

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

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

  6. [BZOJ4003][JLOI2015]城池攻占(左偏树)

    这题有多种做法,一种是倍增预处理出每个点往上走2^i步最少需要的初始战斗力,一种是裸的启发式合并带标记splay. 每个点合并能攻占其儿子的所有骑士,删去所有无法攻占这个城市的骑士并记录答案. 注意到 ...

  7. BZOJ4003 [JLOI2015]城池攻占 左偏树 可并堆

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ4003 题意概括 题意有点复杂,直接放原题了. 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑 ...

  8. bzoj 4003 [JLOI2015]城池攻占 —— 左偏树

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4003 其实蛮简单的,首先一个城市只会被其子树中的骑士经过,启发我们 dfs 序用可并堆合并子 ...

  9. bzoj 4003: 城池攻占 左偏树

    题目大意 http://www.lydsy.com/JudgeOnline/problem.php?id=4003 题解 一开始看漏条件了 题目保证当占领城池可以使攻击力乘上\(v_i\)时,一定有\ ...

随机推荐

  1. 我也是醉了,Eureka 延迟注册还有这个坑!

    Eureka 有个延迟注册的功能,也就是在服务启动成功之后不立刻注册到 Eureka Server,而是延迟一段时间再去注册,这样做的主要目的是因为虽然服务启动成功了,可能还有一些框架或者业务的代码没 ...

  2. 2022-7-15 pan小堂 数组排序算法

    二分查找(理解) public ych class{ public static void main(String[] args){ ///运用二分查找需要 数组在的值是递升的 int[] arr1 ...

  3. Linux、Ubuntu常用命令

    # 文件解压缩 # zip压缩目录(附带目录权限) zip -q -r html.zip /home/html 压缩目录 tar -zcvf pack.tar.gz pack/ #打包压缩为一个.gz ...

  4. 一文带你弄懂 CDN 技术的原理

    对于 CDN 这个东西,相信大家都有耳闻,感觉既陌生但又熟悉.最近深入了解了一下 CDN,这才发现原来 CDN 如此重要!今天就跟大家科普一下 CDN 是什么,以及为啥要有 CDN,最后再讲一下 CD ...

  5. uniapp中用canvas实现小球碰撞的小动画

    uniapp 我就不想喷了,踩了很多坑,把代码贡献出来让大家少踩些坑. 实现的功能: 生成n个球在canvas中运动,相互碰撞后会反弹,反弹后的速度计算我研究过了,可以参考代码直接用 防止球出边框 防 ...

  6. Visual Studio Code 中文设置教程

    本文仅供学习交流使用,如侵立删!demo下载见文末 Pycharm中文设置教程 1.首先打开VisualStudioCode,点击扩展:extensions. 2.搜索chinese. 3.选择需要的 ...

  7. 微信小程序检查版本更新并重启

    目录 1,前言 2,解决方案 3,调试须知 1,前言 最近开发小程序时候碰上了一个问题,当发布新版本小程序后,需要用户能赶紧用上最新的,避免出问题.查了一下官方文档,总结出几个情况如下: 微信运行时, ...

  8. 解决:Uncaught TypeError: $ is not a function

    本来好好的,突然就出现的错误,不过这并不是什么难解决的错误: 我的问题是:在js文件里我定义了一个var $;变量,只要把这个去掉就没问题了. 出现这种错误的解决方法: 1,先看看你的jq文件是否已经 ...

  9. 【Java】学习路径33-在IDEA中使用junit单元测试运行单个方法

    首先在菜单找到 文件-项目结构 项目设置-库-"+" 选择Java 找到IDEA安装目录,打开lib/junit4.jar 的jar包,然后打开即可. 然后选择确定. 然后再项目中 ...

  10. C# winfrom ListView控件实现自由设置每一行字体及背景色等

    背景:公司经常会需要将日志信息,输出到一个对话框中显示出来.之前一直采用的listbox控件,操作简单,使用方便,但是遗憾的是,不能自由控制每一行的状态. 于是想了如下几个方案: (1)重绘listb ...