题目

题解

很明显的 \(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. 这可能是最全的SpringBoot3新版本变化了!

    11月24号,Spring Boot 3.0 发布了第一个正式的 GA 版本,一起看看新版本到底有哪些变化. 2.7版本升级指南 官方提供了一个从 2.7 版本升级到 3.0 的指南:https:// ...

  2. TornadoFx的TableView组件使用

    原文: TornadoFx的TableView组件使用 - Stars-One的杂货小窝 最近慢慢地接触了JavaFx中的TableView的使用,记下笔记总结 使用 1.基本使用 TornadoFx ...

  3. WPF中的“资源”

    WPF中的"资源" 资源概述 WPF中的资源的概念有点类似 web 技术中的静态资源的概念.可以是一个样式,也可以是一个button的边框设置集合. 可以简单的将资源分为如下几个类 ...

  4. 【JVM故障问题排查心得】「内存诊断系列」Docker容器经常被kill掉,k8s中该节点的pod也被驱赶,怎么分析?

    背景介绍 最近的docker容器经常被kill掉,k8s中该节点的pod也被驱赶. 我有一个在主机中运行的Docker容器(也有在同一主机中运行的其他容器).该Docker容器中的应用程序将会计算数据 ...

  5. gtest学习教程(从0到1)

    gtest使用教程 1 简介 之前对gtest一无所知,最近,找了些相关的资料,学习了下.这里主要记录了学习过程和相关知识点. 什么是gtest: gtest测试框架是在不同平台上(Linux,Mac ...

  6. 详解Python当中的pip常用命令

    原文链接:https://mp.weixin.qq.com/s/GyUKj_7mOL_5bxUAJ5psBw 安装 在Python 3.4版本之后以及Python 2.7.9版本之后,官网的安装包当中 ...

  7. Spring IOC官方文档学习笔记(三)之依赖项

    1.依赖注入 (1) 依赖注入(DI)的概念:某个bean的依赖项,由容器来负责注入维护,而非我们自己手动去维护,以此来达到bean之间解耦的目的,如下 //情况一:不使用依赖注入 public cl ...

  8. [编程基础] C和C++内置宏说明

    文章目录 1 内置的宏定义 2 运行平台宏 3 编译器宏 4 调试类型宏 5 代码 C和C++内置宏在代码调试.跨系统平台代码中会经常使用,本文记录说明一下.内置宏不需要调用头文件,可直接使用.在使用 ...

  9. BZOJ4919 大根堆(树形dp+线段树合并)

    用 multiset 启发式合并贪心维护 LIS 的做法就不多说了,网上题解一大堆,着重讲一下线段树合并维护 \(dp\). \(O(n^2)\) 的 \(dp\) 非常显然.离散化后,设 \(dp[ ...

  10. 物以类聚人以群分,通过GensimLda文本聚类构建人工智能个性化推荐系统(Python3.10)

    众所周知,个性化推荐系统能够根据用户的兴趣.偏好等信息向用户推荐相关内容,使得用户更感兴趣,从而提升用户体验,提高用户粘度,之前我们曾经使用协同过滤算法构建过个性化推荐系统,但基于显式反馈的算法就会有 ...