\(\mathscr{Description}\)

  Link.

  给定一棵含有 \(n\) 个结点的有根树, 点 \(u\) 有正权 \(w_u\). 每次操作可以:

  • 在 \(u\) 上放 \(w_u\) 枚石子. 必须满足 \(u\) 的儿子全部都放了对应数量的石子.
  • 回收结点 \(u\) 上的所有石子.

  对于每个点, 求为了在这个点上放上石子, 至少需要准备多少枚石子.

  \(n\le2\times10^5\).

\(\mathscr{Solution}\)

  限制条件为 "儿子选完父亲选", 我们知道 "父亲选完儿子选" 有经典的贪心结论, 所以可以反过来考虑决策顺序.

  对于点 \(u\) 单独的操作, 可以描述为二元组 \((w_u-\sum w_v,w)\), 表示本次操作需要准备 \(w\) 枚石子, 操作完成后石子的变化量为 \(w_u-\sum w_v\). 对于二元组 \((a,b),(c,d)\) 依次合并, 显然有 \((a,b)+(c,d)=(a+c,\max\{b,a+d\})\). 二元组操作顺序只需要依据操作后需准备石子的数量关系, 取数量最小的一种即可. 这是一个用于贪心的偏序关系.

  正如前文所说, 如果是 "父亲选完选儿子", 可以反复找出全局最优解与父亲合并. 而这里, 我们可把整个决策倒过来. 那么 \((a,b)\rightarrow (-a,b-a)\), 在按照结论即可合并. 据此模拟出全局最有的操作策略, 在这一顺序上建立线段树, 线段树合并维护每棵子树的策略二元组之和就能求出答案. 复杂度 \(\mathcal O(n\log n)\).

\(\mathscr{Code}\)

/*+Rainybunny+*/

#include <bits/stdc++.h>

#define rep(i, l, r) for (int i = l, rep##i = r; i <= rep##i; ++i)
#define per(i, r, l) for (int i = r, per##i = l; i >= per##i; --i) typedef long long LL;
typedef std::pair<LL, LL> PLL;
#define fi first
#define se second template <typename Tp>
inline void chkmin(Tp& u, const Tp& v) { v < u && (u = v, 0); }
template <typename Tp>
inline void chkmax(Tp& u, const Tp& v) { u < v && (u = v, 0); }
template <typename Tp>
inline Tp imin(const Tp& u, const Tp& v) { return u < v ? u : v; }
template <typename Tp>
inline Tp imax(const Tp& u, const Tp& v) { return u < v ? v : u; } const int MAXN = 2e5;
int n, fa[MAXN + 5], val[MAXN + 5], ord[MAXN + 5], root[MAXN + 5];
std::vector<int> adj[MAXN + 5], fol[MAXN + 5];
bool vis[MAXN + 5];
LL sub[MAXN + 5], ans[MAXN + 5];
PLL wgt[MAXN + 5]; struct DSU {
int fa[MAXN + 5];
inline void init() {
rep (i, 1, n) fa[i] = i;
}
inline int find(const int x) {
return x == fa[x] ? x : fa[x] = find(fa[x]);
}
inline void unite(const int x, const int y) {
fa[find(x)] = find(y);
}
} dsu; inline PLL operator + (const PLL& u, const PLL& v) {
return { u.fi + v.fi, imax(u.se, u.fi + v.se) };
} struct CmpFn {
inline bool operator () (const int u, const int v) const {
LL d = (wgt[u] + wgt[v]).se - (wgt[v] + wgt[u]).se;
if (d) return d < 0;
if (wgt[u] != wgt[v]) return wgt[u] < wgt[v];
return u < v;
}
};
std::set<int, CmpFn> heap; inline void append(const int u) {
assert(!vis[u]);
ord[u] = ++ord[0], vis[u] = true;
for (int v: fol[u]) append(v);
} struct SegmentTree {
static const int MAXND = 4e6;
int node, ch[MAXND][2]; PLL uni[MAXND]; inline void pushup(const int u) {
uni[u] = uni[ch[u][0]] + uni[ch[u][1]];
} inline void merge(int& u, const int v) {
if (!u || !v) return void(u |= v);
merge(ch[u][0], ch[v][0]), merge(ch[u][1], ch[v][1]);
pushup(u);
} inline void insert(int& u, const int l, const int r,
const int x, const PLL& w) {
if (!u) u = ++node;
if (l == r) return void(uni[u] = w);
int mid = l + r >> 1;
if (x <= mid) insert(ch[u][0], l, mid, x, w);
else insert(ch[u][1], mid + 1, r, x, w);
pushup(u);
}
} sgt; inline void solve(const int u) {
for (int v: adj[u]) solve(v), sgt.merge(root[u], root[v]);
sgt.insert(root[u], 1, n, ord[u], { sub[u] - val[u], sub[u] });
ans[u] = (PLL(val[u], val[u]) + sgt.uni[root[u]]).se;
} int main() {
scanf("%*d %d", &n);
rep (i, 2, n) scanf("%d", &fa[i]), adj[fa[i]].push_back(i);
rep (i, 1, n) scanf("%d", &val[i]), sub[fa[i]] += val[i]; dsu.init();
rep (i, 1, n) wgt[i] = { sub[i] - val[i], sub[i] }, heap.insert(i);
rep (i, 1, n) {
int u = *heap.begin();
// fprintf(stderr, "%d\n", u);
heap.erase(heap.begin());
if (u == 1 || vis[fa[u]]) append(u);
else {
int v = dsu.find(fa[u]);
heap.erase(v);
wgt[v] = wgt[v] + wgt[u], dsu.unite(u, v);
heap.insert(v), fol[v].push_back(u);
}
} solve(1);
rep (i, 1, n) printf("%lld%c", ans[i], i < n ? ' ' : '\n');
return 0;
}

Solution -「UOJ #418」三角形的更多相关文章

  1. Solution -「UOJ #46」玄学

    \(\mathcal{Description}\)   Link.   给定序列 \(\{a_n\}\) 和 \(q\) 次操作,操作内容如下: 给出 \(l,r,k,b\),声明一个修改方案,表示 ...

  2. Solution -「UOJ #87」mx 的仙人掌

    \(\mathcal{Description}\)   Link.   给出含 \(n\) 个结点 \(m\) 条边的仙人掌图.\(q\) 次询问,每次询问给出一个点集 \(S\),求 \(S\) 内 ...

  3. Solution -「UOJ #450」复读机

    \(\mathcal{Description}\)   Link.   求从 \(m\) 种颜色,每种颜色无限多的小球里选 \(n\) 个构成排列,使得每种颜色出现次数为 \(d\) 的倍数的排列方案 ...

  4. Solution -「ARC 104E」Random LIS

    \(\mathcal{Description}\)   Link.   给定整数序列 \(\{a_n\}\),对于整数序列 \(\{b_n\}\),\(b_i\) 在 \([1,a_i]\) 中等概率 ...

  5. Solution -「UNR #5」「UOJ #671」诡异操作

    \(\mathcal{Desciprtion}\)   Link.   给定序列 \(\{a_n\}\),支持 \(q\) 次操作: 给定 \(l,r,v\),\(\forall i\in[l,r], ...

  6. Solution -「JOISC 2020」「UOJ #509」迷路的猫

    \(\mathcal{Decription}\)   Link.   这是一道通信题.   给定一个 \(n\) 个点 \(m\) 条边的连通无向图与两个限制 \(A,B\).   程序 Anthon ...

  7. Solution -「UR #21」「UOJ #632」挑战最大团

    \(\mathcal{Description}\)   Link.   对于简单无向图 \(G=(V,E)\),定义它是"优美"的,当且仅当 \[\forall\{a,b,c,d\ ...

  8. Solution -「UR #2」「UOJ #32」跳蚤公路

    \(\mathcal{Description}\)   Link.   给定一个 \(n\) 个点 \(m\) 条边的带权有向图,每条边还有属性 \(s\in\{-1,0,1\}\).对于每个 \(u ...

  9. Solution -「CTS 2019」「洛谷 P5404」氪金手游

    \(\mathcal{Description}\)   Link.   有 \(n\) 张卡牌,第 \(i\) 张的权值 \(w_i\in\{1,2,3\}\),且取值为 \(k\) 的概率正比于 \ ...

  10. Solution -「BZOJ 3812」主旋律

    \(\mathcal{Description}\)   Link.   给定含 \(n\) 个点 \(m\) 条边的简单有向图 \(G=(V,E)\),求 \(H=(V,E'\subseteq E)\ ...

随机推荐

  1. .NET云原生应用实践(五):使用Blazor WebAssembly实现前端页面

    本章目标 使用Blazor WebAssembly实现管理"贴纸"页面 集成认证与授权机制 如果你对Blazor WebAssembly的使用不感兴趣,可以跳过本章的阅读.你也可以 ...

  2. 网站免费https加密教程

    为网站实现HTTPS加密可以大大提高网站的安全性和用户信任度.以下是一个详细的免费HTTPS加密教程: 一.选择免费SSL证书提供商 JoySSL:这是目前国内为数不多的国产CA服务商打造的自主品牌S ...

  3. FreeRTOS-Error: ..\FreeRTOS\portable\RVDS\ARM_CM4F\port.c, 271

    任务运行时间API函数的应用 当使用任务运行时间API函数打印任务运行时间等相关信息是,串口打印出现这个问题 网上是这么说的 但是运行每个任务都可以执行进去,循序时间API函数也可以执行进去,就是无法 ...

  4. Springboot集成WebSocket实现智能聊天【Demo】

    背景 openai 目前越来越流行,其他 ai 产业也随之而来,偶然翻到 openai接口文档,就想着可以调用接口实现智能聊天,接下来就写写我怎么接入 websocket 的过程,文笔不佳,谅解. 接 ...

  5. 集成Nacos

    版本统一:Spring Boot 2.6.11,Spring Cloud 2021.0.4,Spring Cloud Alibaba 2021.0.4.0: Maven 仓库记得配置中央仓库,私服上有 ...

  6. Java日志记录几种实现方案

    在平时使用到一些软件中,比如某宝或者某书,通过记录用户的行为来构建和分析用户的行为数据,同时也能更好优化产品设计和提升用户体验.比如在一个订单系统中,需要确定追踪用户的行为,比如: 登录/登出 浏览商 ...

  7. windows server系统中,Pro运行深度学习工具错误

    安装深度学习包后,运行相关工具的时候报错,缺失cv2的模块. 在arcpy执行窗口,直接去引入cv2包的时候,确实发了错误. 查看了相关路径,确认cv2的包,在对应路径已经存在,也有对应的元数据信息, ...

  8. 《JavaScript 模式》读书笔记(8)— DOM和浏览器模式2

    四.长期运行脚本 可能会注意到有时候浏览器会提示某个脚本已经运行了很长时间,是否应该停止该脚本.实际上无论要处理多么复杂的任务,都不希望应用程序发生上述事情.而且,如果该脚本的工作十分繁重,那么浏览器 ...

  9. Chrome浏览器本地安装插件

    前情 Chrome是目前世面上很受欢迎的浏览器,你可以通过它的插件扩展功能安装插件优化使用体验和增加功能. 坑位 对于国内受墙影响的用户无法直接通过应用商店安装插件,通过离线安装插件会发现浏览器会提示 ...

  10. 鸿蒙UI开发快速入门 —— part06:组件状态管理之@State装饰器

    1.说在前面的话 在前五个章节中,我们构建的页面基本都是静态的页面,如果希望构建一个动态的.有交互的界面,就需要引入"状态"的概念,以便随着用户的交互,界面随着发生变化,例如如下的 ...