dsu on tree 模板
1.并查集模板2.求质因数模板3.二分图最大匹配模板(匈牙利算法)4.欧拉函数模板5.ST表模板6.快速幂模板7.字典树模板8.矩阵模板9.Dijkstra单源最短路模板10.最近公共祖先模板(LCA)11.拓扑排序模板12.区间素数筛模板13.Kruskal和Prim模板14.树状数组模板15.二维坐标离散化模板16.单点修改区间查最值-树状数组模板17.KMP模板18.二叉搜索树模板19.DIjkstra进阶模板 路径记录 按权重(结点数最小等)记录20.判断负环模板21.Exgcd 模板22.压位高精度模板23.线段树模板24.扫描线模板25.莫队模板26.带修莫队模板27.SCC缩点模板28.取模+组合数29.FFT 高精度乘法模板30.字符串自然溢出哈希/单哈希/双哈希模板31.树模板
32.dsu on tree 模板
33.线段树模板重制34.主席树模板35.大数质因数分解模板36.线段树合并模板37.int128输入输出流38.Meissel_Lehmer模板39.浮点高精度40.自适应辛普森法41.unordered_map随机底数种子dsu on tree模板运用
例题以及代码:
U41492 树上数颜色 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
记录详情 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
Lomsat gelral - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
记录详情 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
struct DsuOnTree { int n, dfn = 0; vector<int> sz, big, L, R, Node; vector<vector<int>> g; //根据题目要求修改 i64 Max = 0, now = 0; vector<i64> ans, cnt, col; DsuOnTree(int n): n(n), sz(n + 1), big(n + 1), L(n + 1), R(n + 1), Node(n + 1) { g.resize(n + 1); ans.resize(n + 1); col.resize(n + 1); cnt.resize(n + 1); } void add(int u, int v) { g[u].emplace_back(v); g[v].emplace_back(u); } void add(int u) { //计算贡献 } void del(int u) { //删除贡献 } i64 getAns() { return now; } void dfs0(int u, int fa) { L[u] = ++dfn; Node[dfn] = u; sz[u] = 1; for (int v : g[u]) if (v != fa) { dfs0(v, u); sz[u] += sz[v]; if (!big[u] || sz[big[u]] < sz[v]) big[u] = v; } R[u] = dfn; } void dfs1(int u, int fa, bool keep) { // 计算轻儿子的答案 for (int v : g[u]) if (v != fa && v != big[u]) { dfs1(v, u, false); } // 计算重儿子答案并保留计算过程中的数据(用于继承) if (big[u]) { dfs1(big[u], u, true); } for (int v : g[u]) if (v != fa && v != big[u]) { // 子树结点的 DFS 序构成一段连续区间,可以直接遍历 for (int i = L[v]; i <= R[v]; i++) { add(Node[i]); } } add(u); ans[u] = getAns(); if (keep == false) { for (int i = L[u]; i <= R[u]; i++) { del(Node[i]); } } } };
本文作者:Ke_scholar
本文链接:https://www.cnblogs.com/Kescholar/p/18328826
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
2023-07-28 SMU Summer 2023 Contest Round 7