题目

题解

很明显的 \(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})\)

然后推一波矩阵

\[\begin{bmatrix}
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】洪水的更多相关文章

  1. LOJ_6045_「雅礼集训 2017 Day8」价 _最小割

    LOJ_6045_「雅礼集训 2017 Day8」价 _最小割 描述: 有$n$种减肥药,$n$种药材,每种减肥药有一些对应的药材和一个收益. 假设选择吃下$K$种减肥药,那么需要这$K$种减肥药包含 ...

  2. 雅礼集训【Day6-1】字符串

    雅礼集训[Day6-1]字符串 假设我们有串\(a\),我们设\(a'\)为\(a\)翻转后按为取反过后的串. 我们只考虑前一半的,长为\(m\)的串.如果前半截匹配了\(a\)或者\(a'\),则\ ...

  3. 「雅礼集训 2017 Day7」事情的相似度

    「雅礼集训 2017 Day7」事情的相似度 题目链接 我们先将字符串建后缀自动机.然后对于两个前缀\([1,i]\),\([1,j]\),他们的最长公共后缀长度就是他们在\(fail\)树上对应节点 ...

  4. 「雅礼集训 2017 Day2」解题报告

    「雅礼集训 2017 Day2」水箱 我怎么知道这种题目都能构造树形结构. 根据高度构造一棵树,在树上倍增找到最大的小于约束条件高度的隔板,开一个 \(vector\) 记录一下,然后对于每个 \(v ...

  5. 「雅礼集训 2017 Day1」 解题报告

    「雅礼集训 2017 Day1」市场 挺神仙的一题.涉及区间加.区间除.区间最小值和区间和.虽然标算就是暴力,但是复杂度是有保证的. 我们知道如果线段树上的一个结点,\(max=min\) 或者 \( ...

  6. [LOJ 6031]「雅礼集训 2017 Day1」字符串

    [LOJ 6031] 「雅礼集训 2017 Day1」字符串 题意 给定一个长度为 \(n\) 的字符串 \(s\), \(m\) 对 \((l_i,r_i)\), 回答 \(q\) 个询问. 每个询 ...

  7. [LOJ 6030]「雅礼集训 2017 Day1」矩阵

    [LOJ 6030] 「雅礼集训 2017 Day1」矩阵 题意 给定一个 \(n\times n\) 的 01 矩阵, 每次操作可以将一行转置后赋值给某一列, 问最少几次操作能让矩阵全为 1. 无解 ...

  8. [LOJ 6029]「雅礼集训 2017 Day1」市场

    [LOJ 6029] 「雅礼集训 2017 Day1」市场 题意 给定一个长度为 \(n\) 的数列(从 \(0\) 开始标号), 要求执行 \(q\) 次操作, 每次操作为如下四种操作之一: 1 l ...

  9. 【LYOI 212】「雅礼集训 2017 Day8」价(二分匹配+最大权闭合子图)

    「雅礼集训 2017 Day8」价 内存限制: 512 MiB时间限制: 1000 ms 输入文件: z.in输出文件: z.out   [分析] 蛤?一开始看错题了,但是也没有改,因为不会做. 一开 ...

  10. loj #6046. 「雅礼集训 2017 Day8」爷

    #6046. 「雅礼集训 2017 Day8」爷 题目描述 如果你对山口丁和 G&P 没有兴趣,可以无视题目背景,因为你估计看不懂 …… 在第 63 回战车道全国高中生大赛中,军神西住美穗带领 ...

随机推荐

  1. Vue3“直接”修改props

    父组件 import { reactive } from 'vue'; //对话框数据 const show = reactive({ isshow: false, }); //打开对话框 const ...

  2. linux内核源码下载地址

    一.官网链接 https://www.kernel.org/ 二.HTTP https://www.kernel.org/pub/ 三.GIT https://git.kernel.org/ 四.镜像 ...

  3. 【Java并发入门】03 互斥锁(上):解决原子性问题

    原子性问题的源头是线程切换 Q:如果禁用 CPU 线程切换是不是就解决这个问题了? A:单核 CPU 可行,但到了多核 CPU 的时候,有可能是不同的核在处理同一个变量,即便不切换线程,也有问题. 所 ...

  4. 【Hadoop学习】补充:优化、新特性

    一.数据压缩 1.概述 原则:IO密集而不是计算密集的job 压缩算法选择 2.压缩位置选择 通过参数进行配置 3.压缩实例: 数据流的压缩和解压缩 Map输出端采用压缩 Reduce输出端采用压缩 ...

  5. JavaScript入门⑧-事件总结大全

    JavaScript入门系列目录 JavaScript入门①-基础知识筑基 JavaScript入门②-函数(1)基础{浅出} JavaScript入门③-函数(2)原理{深入}执行上下文 JavaS ...

  6. 把ChatGPT配置到微信群里,可以对AI提问了!

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言:用的很爽! 自从小傅哥用上 ChatGPT 连搜索引擎用的都不多了,很多问题的检索我 ...

  7. [深度学习] CNN的基础结构与核心思想

    1. 概述 卷积神经网络是一种特殊的深层的神经网络模型,它的特殊性体现在两个方面,一方面它的神经元间的连接是非全连接的, 另一方面同一层中某些神经元之间的连接的权重是共享的(即相同的).它的非全连接和 ...

  8. vue多界面开发

    1. 安装 vue-cli,已有的请跳过这一步 npm install -g @vue/cli 若已安装旧版 vue-cli 则需要先卸载 vue-cli npm uninstall -g vue-c ...

  9. 网络流棋盘模型 | P3355 骑士共存问题 P4304 [TJOI2013]攻击装置

    题面(骑士共存问题) 在一个 \(n \times n\) 个方格的国际象棋棋盘上,马(骑士)可以攻击的棋盘方格如图所示.棋盘上某些方格设置了障碍,骑士不得进入. 对于给定的 \(n \times n ...

  10. 图文并茂的学习笔记--微信小程序自定义tabbar

    我发现自带的那个tabbar不可以修改样式,没得搞啊,这不行,要改 首先,我们看文档,地址在下面 https://developers.weixin.qq.com/miniprogram/dev/fr ...