JZOJ 4043. 【雅礼集训2015Kzf】洪水
题目

题解
很明显的 \(dp\)
\(f_u = \min(a_u, \sum_{(u,v) \in E}f_v)\)
然后套路的设 \(g_u\) 表示不管重儿子的 \(f_u\)
\(f_u = \min(a_u, g_u+f_{\text{son}_v})\)
然后推一波矩阵
g_u&a_u\\
\infty&0
\end{bmatrix}\otimes
\begin{bmatrix}
f_{\text{son}_u} \\
0
\end{bmatrix}=
\begin{bmatrix}
f_u\\
0
\end{bmatrix}
\]
\(Code\)
#include<cstdio>
#include<iostream>
#define LL long long
#define ls (p << 1)
#define rs (ls | 1)
using namespace std;
const int N = 2e5 + 5;
const LL INF = 0x3f3f3f3f3f3f3f3f;
int n, m, a[N], h[N], tot;
LL f[N], g[N];
struct edge{int to, nxt;}e[N << 1];
inline void add(int x, int y){e[++tot] = edge{y, h[x]}, h[x] = tot;}
int siz[N], fa[N], son[N], top[N], dfn[N], bot[N], dfc;
void dfs1(int x)
{
siz[x] = 1;
for(register int i = h[x]; i; i = e[i].nxt)
{
int v = e[i].to;
if (v == fa[x]) continue;
fa[v] = x, dfs1(v), siz[x] += siz[v], f[x] += f[v];
if (siz[v] > siz[son[x]]) son[x] = v;
}
if (siz[x] == 1) f[x] = a[x];
else f[x] = min(f[x], 1LL * a[x]);
}
void dfs2(int x)
{
dfn[x] = ++dfc;
if (son[x]) top[son[x]] = top[x], dfs2(son[x]);
else bot[top[x]] = dfn[x], g[x] = INF;
for(register int i = h[x]; i; i = e[i].nxt)
{
int v = e[i].to;
if (v == son[x] || v == fa[x]) continue;
top[v] = v, g[x] += f[v], dfs2(v);
}
}
struct Matrix{
LL a[2][2];
inline Matrix(){a[0][0] = a[0][1] = a[1][0] = a[1][1] = INF;}
inline Matrix operator*(const Matrix &b)
{
Matrix c;
for(register int i = 0; i < 2; i++)
for(register int j = 0; j < 2; j++)
for(register int k = 0; k < 2; k++)
c.a[i][j] = min(c.a[i][j], a[i][k] + b.a[k][j]);
return c;
}
}seg[N << 2];
struct Matrix Node(LL _g, LL _a)
{
Matrix c;
c.a[0][0] = _g, c.a[0][1] = _a, c.a[1][0] = INF, c.a[1][1] = 0;
return c;
}
struct Matrix I()
{
Matrix c;
c.a[0][0] = c.a[1][1] = 0, c.a[0][1] = c.a[1][0] = INF;
return c;
}
void update(int p, int l, int r, int x, Matrix v)
{
if (l == r) return void(seg[p] = v);
int mid = (l + r) >> 1;
if (x <= mid) update(ls, l, mid, x, v);
else update(rs, mid + 1, r , x, v);
seg[p] = seg[ls] * seg[rs];
}
Matrix query(int p, int l, int r, int tl, int tr)
{
if (tl <= l && r <= tr) return seg[p];
int mid = (l + r) >> 1;
Matrix ret = I();
if (tl <= mid) ret = query(ls, l, mid, tl, tr);
if (tr > mid) ret = ret * query(rs, mid + 1, r, tl, tr);
return ret;
}
inline void change(int x)
{
while (x)
{
update(1, 1, n, dfn[x], Node(g[x], a[x])), x = top[x];
Matrix ret = query(1, 1, n, dfn[x], bot[x]);
g[fa[x]] -= f[x], f[x] = min(ret.a[0][0], ret.a[0][1]), g[fa[x]] += f[x];
x = fa[x];
}
}
int main()
{
scanf("%d", &n);
for(register int i = 1; i <= n; i++) scanf("%d", a + i);
for(register int i = 1, u, v; i < n; i++) scanf("%d%d", &u, &v), add(u, v), add(v, u);
dfs1(1), top[1] = 1, dfs2(1);
for(register int i = 1; i <= n; i++) update(1, 1, n, dfn[i], Node(g[i], a[i]));
scanf("%d", &m);
char op[5];
for(int x, to; m; --m)
{
scanf("%s%d", op, &x);
if (op[0] == 'Q')
{
Matrix ret = query(1, 1, n, dfn[x], bot[top[x]]);
printf("%lld\n", min(ret.a[0][0], ret.a[0][1]));
}
else scanf("%d", &to), a[x] += to, change(x);
}
}
JZOJ 4043. 【雅礼集训2015Kzf】洪水的更多相关文章
- LOJ_6045_「雅礼集训 2017 Day8」价 _最小割
LOJ_6045_「雅礼集训 2017 Day8」价 _最小割 描述: 有$n$种减肥药,$n$种药材,每种减肥药有一些对应的药材和一个收益. 假设选择吃下$K$种减肥药,那么需要这$K$种减肥药包含 ...
- 雅礼集训【Day6-1】字符串
雅礼集训[Day6-1]字符串 假设我们有串\(a\),我们设\(a'\)为\(a\)翻转后按为取反过后的串. 我们只考虑前一半的,长为\(m\)的串.如果前半截匹配了\(a\)或者\(a'\),则\ ...
- 「雅礼集训 2017 Day7」事情的相似度
「雅礼集训 2017 Day7」事情的相似度 题目链接 我们先将字符串建后缀自动机.然后对于两个前缀\([1,i]\),\([1,j]\),他们的最长公共后缀长度就是他们在\(fail\)树上对应节点 ...
- 「雅礼集训 2017 Day2」解题报告
「雅礼集训 2017 Day2」水箱 我怎么知道这种题目都能构造树形结构. 根据高度构造一棵树,在树上倍增找到最大的小于约束条件高度的隔板,开一个 \(vector\) 记录一下,然后对于每个 \(v ...
- 「雅礼集训 2017 Day1」 解题报告
「雅礼集训 2017 Day1」市场 挺神仙的一题.涉及区间加.区间除.区间最小值和区间和.虽然标算就是暴力,但是复杂度是有保证的. 我们知道如果线段树上的一个结点,\(max=min\) 或者 \( ...
- [LOJ 6031]「雅礼集训 2017 Day1」字符串
[LOJ 6031] 「雅礼集训 2017 Day1」字符串 题意 给定一个长度为 \(n\) 的字符串 \(s\), \(m\) 对 \((l_i,r_i)\), 回答 \(q\) 个询问. 每个询 ...
- [LOJ 6030]「雅礼集训 2017 Day1」矩阵
[LOJ 6030] 「雅礼集训 2017 Day1」矩阵 题意 给定一个 \(n\times n\) 的 01 矩阵, 每次操作可以将一行转置后赋值给某一列, 问最少几次操作能让矩阵全为 1. 无解 ...
- [LOJ 6029]「雅礼集训 2017 Day1」市场
[LOJ 6029] 「雅礼集训 2017 Day1」市场 题意 给定一个长度为 \(n\) 的数列(从 \(0\) 开始标号), 要求执行 \(q\) 次操作, 每次操作为如下四种操作之一: 1 l ...
- 【LYOI 212】「雅礼集训 2017 Day8」价(二分匹配+最大权闭合子图)
「雅礼集训 2017 Day8」价 内存限制: 512 MiB时间限制: 1000 ms 输入文件: z.in输出文件: z.out [分析] 蛤?一开始看错题了,但是也没有改,因为不会做. 一开 ...
- loj #6046. 「雅礼集训 2017 Day8」爷
#6046. 「雅礼集训 2017 Day8」爷 题目描述 如果你对山口丁和 G&P 没有兴趣,可以无视题目背景,因为你估计看不懂 …… 在第 63 回战车道全国高中生大赛中,军神西住美穗带领 ...
随机推荐
- Day24.1:抽象类的详解
抽象类 1.1抽象类概述 一个动物类中,我们创建对象时会去new一个动物:但是我们不应该直接创建动物这个对象,因为动物本身就是抽象的,没有动物这种实例,我们创建的应该是一个具体的动物类,比如猫.狗等动 ...
- MyEclipse连接MySQL
在官网http://www.mysql.com/downloads/下载数据库连接驱动 本文中使用驱动版本为mysql-connector-java-5.1.40 一.创建一个java测试项目MySQ ...
- C++编程笔记(QT)
目录 入门基础 模态对话框 消息提示框(messagebox) 文件和目录 字体选择框 输入对话框 进度条 工具栏 控件布局 Windows托盘案例 控件 button 下拉菜单按钮 `radioBu ...
- 【每日一题】【直接循环&二分查找】2022年2月10日-NC32 求平方根
描述实现函数 int sqrt(int x).计算并返回 x 的平方根(向下取整) 方法1:直接循环 import java.util.*; public class Solution { /** * ...
- 【FAQ】在华为鸿蒙车机上集成华为帐号的常见问题总结
随着新一代信息技术与汽车产业的深度融合,智能网联汽车正逐渐成为汽车产业发展的战略制高点,无论是传统车企还是新势力都瞄准了"智能座舱"这种新一代人机交互方式.面对竞争如此激烈的车机市 ...
- vue elementui弹框内 富文本编辑器的使用,及踩坑
最近vue项目中遇到弹框内使用富文本编辑器,遇到最大的问题是,在打开弹框后才能创建富文本编辑器,并且只能创建一次,多次点击弹框,报错: Error in v-on handler: "Err ...
- HNCTF的pyjail做题过程详解
简述: 因为本人对python的内置函数理解也不是深入,在做题过程中也是靠着出题人的hint和google大法才做出来几题,详细的解题过程和知识点讲解可以看一下春哥的知乎,[PyJail] pytho ...
- WCF 服务容器化的一些问题
背景 目前项目当中存有 .NET Framework 和 .NET Core 两种类型的项目,但是都需要进行容器化将其分别部署在 Windows 集群和 Linux 集群当中.在 WCF 进行容器化的 ...
- 2023牛客寒假算法基础集训营2 ABCDEFHJKL
比赛链接 A 题解 知识点:数学. 用 \(n\) 减去区间1的端点得到匹配的一个区间,求一下与区间2的交集. 一个小公式,两区间 \([L_1,R_1]\) 和 \([L_2,R_2]\) 的交集长 ...
- Ubuntu desktop 文件的书写格式
首先切换到存放 desktop 文件的目录下,编辑好就可以保存了 cd /usr/share/applications/ vim name.desktop [Desktop Entry] Name=显 ...