题解:P9194 [USACO23OPEN] Triples of Cows P

news/2026/1/22 18:24:17/文章来源:https://www.cnblogs.com/dyc2022/p/19518633

更差的阅读体验


我们发现一棵树删掉一个点之后会在删掉点的位置形成一个团,这很坏。我们希望还能形成一棵树。

所以我们考虑对这个图建圆方树。

我们以 \(n\) 为根,这样这个点不会被删掉。然后假设方点 \(u\) 的儿子个数为 \(s_u\)

考虑题目要我们数的三元组 \((a, b, c)\) 的数量。假设圆点 \(a, b\) 中间是方点 \(x\)\(b, c\) 之间方点是 \(y\),那么考虑按照以下讨论来统计答案:

  1. \(x = y\)。那么枚举这个方点,在它的邻居中随便选三个点都可以。它有 \(s_x + 1\) 个邻居,那么方案数是 \((s_x + 1) s_x (s_x - 1)\)
  2. \(x \not = y\)\(x, y\) 都是 \(b\) 的儿子,如图。

那么我们要数的就是在 \(b\) 的孙子中挑选出两个圆点 \(a, c\)\(a, c\)\(b\) 的不同子树。那就是在 \(b\) 的孙子中随便挑两个的方案数,减去在每个子树里挑两个孙子的方案数。也就是

\[(\sum_{x \isin son_b} s_x) ^ 2 - \sum_{x \isin son_b} s_x ^ 2 \]

对于后半部分,对于所有 \(b\),每个 \(x\) 只会被计算一次,所以可以拆出来。

在这种情况下,我们需要知道一个圆点 \(u\) 的所有儿子的 \(s\) 之和。这个我们称为 \(S_u\),只有圆点有定义。在实现中我把 \(S\)\(s\) 存在同一个数组里。

  1. \(x \not = y\)\(x, y\) 都是 \(b\) 的儿子,如图。

我们不妨假设 \(b\) 的父亲是 \(x\),最后 \(\times 2\) 就能得到另一半的方案数。那么我们考虑在 \(x\) 处计算贡献。

首先我们要先选出 \(b\),然后再选出 \(y\),在 \(b, y\) 确定的情况下,选出 \(c\) 的方案数也就是 \(y\) 的儿子数量 \(s_y\)。然后我们还要选出 \(a\)。由于 \(x\)\(s_x + 1\) 个邻居,有一个是 \(b\) 已经被选择了,所以选 \(a\) 的方案数是 \(s_x\)。所以 \(x\) 的贡献是

\[2 s_x \sum_{b \isin son_x} \sum_{y \isin son_b} s_y \]

我们发现在这种情况下,我们需要知道一个方点孙子的 \(s\) 之和,不妨设 \(x\) 孙子的 \(s\) 之和为 \(t_x\)

所以综合以上三种情况,为了让式子比较好看,我们假设 \(f(x) = x^3 - x^2 - x\),那么答案就是

\[\sum_x(f(s_x) + 2s_x t_x) + \sum_b S_b^2 \]

\(x\) 是方点,\(b\) 是圆点。只要我们能动态维护 \(s_x, t_x, S_b\),这道题就做完了。


我们考虑删点的时候是在做什么。当我们删掉一个圆点,我们会把它邻居的所有方点合并,也就是把它的儿子全部合并到它的父亲上。

这个复杂度可能不太对,因为它的儿子这个时候可能有一些也是从下面合并上来的,所以合并次数之和不一定是 \(O(n)\) 的。但是我们发现我们可以在合并 \(v \to u\) 时,把合并产生的贡献挂在 \(u\) 上,类似于打标记,等下次 \(u\) 合并到另外一个结点时,把这个标记再复制到另外一个结点。

所以我们只需要对原圆方树上的点的儿子进行合并即可,也就是对没合并过的儿子进行合并。这样一个儿子只就合并一次,复杂度就对了。

我们一次删点 \(u\) 要删除 \(u\) 的每个儿子,并且要更新 \(u\) 的父亲,爷爷,曾祖父的权值。第一部分的和是 \(O(n)\) 的,第二部分是 \(O(1)\) 的。这一部分细节比较多,代码里有注释说每一步在做什么。

并查集维护即可。每次合并后更新答案。

那么这道题就做完了,复杂度 \(O(n \alpha(n))\)

#include<bits/stdc++.h>
#define endl '\n'
#define N 400006
using namespace std;
using i64=long long;
int n,s[N],t[N],f[N],fa[N];
vector<int> G[N]; i64 ans;
inline void add(int u,int v) {G[u].push_back(v),G[v].push_back(u);}
inline int find(int k) {return f[k]==k?k:f[k]=find(f[k]);}
void dfs(int u)
{for(int v:G[u])if(v!=fa[u]){fa[v]=u,dfs(v);if(u>n)s[u]++,t[u]+=s[v];else s[u]+=s[v];}
}
inline i64 fc(int x) {return -1ll*x*x-x+1ll*x*x*x;}
inline i64 calc(int i) {return fc(s[i])+2ll*s[i]*t[i];}
inline void del(int u)
{int ft=find(fa[u]),g=fa[ft];//去掉父亲和爷爷的贡献 ans-=calc(ft)+1ll*s[g]*s[g],s[g]-=s[ft],s[ft]--;//去掉自己的贡献 t[ft]-=s[u],ans-=1ll*s[u]*s[u],s[u]=0; int ss=-1;//ss 表示 u 的父亲的 s 增加了多少 //初始为 -1 是因为 u 的父亲的 s 减掉了 u 一个 for(int v:G[u])if(v!=fa[u])//把 u 的儿子方点 v 删掉,并入 u 的父亲f[v]=ft,s[ft]+=s[v],ss+=s[v],t[ft]+=t[v],ans-=calc(v),s[v]=t[v]=0;//u 的父亲 s 增加多少,u 的爷爷 s 就增加多少,u 的曾祖父的 t 就增加增加多少s[g]+=s[ft],ans+=calc(ft)+1ll*s[g]*s[g];//更新曾祖父 int gg=find(fa[fa[ft]]); t[gg]+=ss,ans+=2ll*s[gg]*ss; 
}
main()
{scanf("%d",&n);for(int i=1,u,v;i<n;i++)scanf("%d%d",&u,&v),add(u,i+n),add(v,i+n);dfs(n);for(int i=1;i<=n;i++)ans+=1ll*s[i]*s[i],f[i]=i;for(int i=n+1;i<n*2;i++)ans+=calc(i),f[i]=i;printf("%lld\n",ans);for(int i=1;i<n;i++)del(i),printf("%lld\n",ans);return 0;
}
/*
考虑建圆方树。
对于点对 (a, b, c),假设连接 ab 的方点是 x,连接 bc 的方点是 y。假设方点 i 的儿子个数为 s[i] 1. x = y,答案是 \sum _x (s[i]+1)s[i](s[i]-1),x 为方点 
2. x \not = y 且 x,y 都是 b 的儿子。答案是sum_{b 为圆点} ( (\sum_x s[x]) ^ 2 - \sum_x s[x] ^ 2) x 为 b 的儿子。
3. x \not = y 且不妨设 x 是 b 的父亲,y 是 b 的儿子,最后乘 2 即可。sum_{x 为方点} 2 s[x] \sum_b \sum_y s[y],b 为 x 的儿子,y 为 b 的儿子。 我们维护: 
方点 s[u]。 
圆点 s[u] 表示其儿子(都是方点)的 s[v] 之和。
t[u] 表示方点的儿子的 s[v] 之和。 圆方树删点用并查集维护即可。这也太难了。 看到一个比较方便的计算形式:
f(x) = x^3 - x^2 - x
ans = \sum_x( f(s[x]) + 2 s[x]t[x] ) + \sum_b s[b]^2
x 为方点,b 为圆点。是不是就做完了。 
*/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1201339.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Node.js 后端架构的“隐秘角落”:从 Fastify 引擎到类型系统的博弈

在构建高性能 Node.js 服务&#xff08;尤其是基于 NestJS&#xff09;时&#xff0c;我们往往会遇到一些反直觉的现象&#xff1a;明明名字一样的类型却报错、明明配置了上传却收不到文件、明明锁定了版本却还要担心依赖树。本文将带你深入后端开发的“隐秘角落”&#xff0c;…

java_ssm42基于Java的服装穿搭信息管理系统的设计与实现_idea项目源码

目录具体实现截图项目背景与意义技术架构与功能模块创新点与优势应用价值系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;具体实现截图 项目背景与意义 随着时尚产业数字化发展&#xff0c;服装穿搭信息管理系…

学生心理健康测评系统任务书

学生心理健康测评系统任务书 一、任务名称 学生心理健康测评系统开发与落地实施 二、任务背景与目的 当前学生群体面临学业、社交、家庭等多重压力&#xff0c;心理健康问题频发&#xff0c;亟需建立科学、高效的测评与干预机制。传统测评依赖纸质问卷、人工统计&#xff0c;存…

tick 数据接入实战:从 tick 行情到系统节奏感

在真正把 tick 数据 接进系统之前&#xff0c;很多人对它的认知都停留在“最小粒度行情”这几个字上。 但当程序跑起来&#xff0c;WebSocket 连上&#xff0c;日志开始滚动时&#xff0c;第一感受往往不是“数据”&#xff0c;而是节奏。 时间戳在跳&#xff0c;价格在抖&…

AI 搜索话语权争夺战,上海geo优化公司排名盘点,源级引擎成企业战略首选

在生成式 AI 重构信息传播规则的今天,GEO(生成式引擎优化)已从可选的营销技术,升级为企业抢占 AI 生态话语权的核心战略资产。上海作为中国数字经济的前沿阵地,2025 年企业在 AI 营销技术领域的投入规模已达 215 …

“新”意十足 · HarmonyOS模板组件(本次上新:求职、回收、旅游攻略模板;发票、估价等组件)

&#x1f4a1; 鸿蒙生态为开发者提供海量的HarmonyOS模板/组件&#xff0c;助力开发效率原地起飞 &#x1f4a1; ★ 更多内容&#xff0c;一键直达生态市场组件&模板市场 , 快速应用DevEco Studio插件市场集成组件&模板 ★ ★ 一键直达 HarmonyOS 行业解决方案 ★ 模…

芜湖抖音巨量广告+巨量本地推开户投流攻略:认准三十六行网络科技,全案运营助力精准获客

芜湖作为长三角经济发展的重要节点,互联网营销需求持续攀升。对于想要借助抖音平台实现品牌推广与精准获客的企业而言,选择一家专业的投流运营公司至关重要。三十六行网络科技 (芜湖分公司),凭借抖音、美团等多平…

java_ssm43健身房管理系统的设计与实现天津大学_idea项目源码

目录 具体实现截图项目背景技术架构核心功能模块创新点与特色应用价值 系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 具体实现截图 项目背景 随着全民健身意识的提升&#xff0c;健身房管理需求日益复杂&a…

“新”意十足 · HarmonyOS模板组件(功能增强:商城、美食、工具等模板;短视频、剪辑等组件)

&#x1f4a1; 鸿蒙生态为开发者提供海量的HarmonyOS模板/组件&#xff0c;助力开发效率原地起飞&#x1f4a1; ★ 更多内容&#xff0c;一键直达生态市场组件&模板市场 , 快速应用DevEco Studio插件市场集成组件&模板 ★ ★ 一键直达 HarmonyOS 行业解决方案 ★ 模板…

2026控油去屑防脱洗发水排行榜:WMP登顶,精准适配不同需求

引言:《2025中国头皮健康消费报告》指出,国内油头伴头屑人群占比已突破62%,其中25-40岁群体占比超70%;而《2025中国头皮健康消费白皮书》进一步披露,同时受出油、头屑、脱发困扰的用户占比达58%,且76%的用户因选…

java_ssm36在线课堂问答教学系统课件 作业考试_idea项目源码

目录具体实现截图项目概述技术架构核心功能特色设计部署说明适用场景系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;具体实现截图 项目概述 Java_SSM36在线课堂问答教学系统基于SSM框架&#xff08;SpringSp…

java_ssm37在线音乐分享平台的设计与实现

目录具体实现截图摘要系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;具体实现截图 摘要 在线音乐分享平台基于Java SSM框架&#xff08;Spring、Spring MVC、MyBatis&#xff09;开发&#xff0c;结合MySQL数…

基于Java+SpringBoot+SSM宠物医院管理系统(源码+LW+调试文档+讲解等)/宠物医院管理软件/宠物医院信息管理系统/宠物医院服务平台/宠物医院管理方案/宠物医院运营系统

博主介绍 &#x1f497;博主介绍&#xff1a;✌全栈领域优质创作者&#xff0c;专注于Java、小程序、Python技术领域和计算机毕业项目实战✌&#x1f497; &#x1f447;&#x1f3fb; 精彩专栏 推荐订阅&#x1f447;&#x1f3fb; 2025-2026年最新1000个热门Java毕业设计选题…

密封性好的渣浆泵有哪些?三大渣浆泵品牌硬核实力大比拼

在矿山、电力、冶金、环保等高磨损、高腐蚀的严苛工况中,渣浆泵的密封性能直接影响设备运行的稳定性、环境清洁度与综合使用成本。优异的密封技术能有效防止浆体泄漏,减少停机维护,提升生产效率。今天,我们基于技术…

环保的渣浆泵厂家推荐:石泵泵业提供高效和可靠的解决方案

在全球产业向绿色、低碳转型的背景下,环保已不再是一道“选择题”,而是所有工业企业必须面对的“必答题”。尤其在矿山、电力、冶金、疏浚等领域,作为关键输送设备的渣浆泵,其性能与环保表现直接关系到生产线的能耗…

你的细胞在窃听:别给身体发“毒代码”

细胞也在“听”你怎么对待生活 一、 身体从来不是“哑巴” 咱们今天聊点稍微“深”一点的话题。 你有没有过这种感觉&#xff1f;明明没干什么体力活&#xff0c;也没搬砖也没扛包&#xff0c;但就是觉得累。那种累&#xff0c;像是浸在骨头缝里的&#xff0c;睡一觉也缓不过…

国产操作系统主流品牌阵营解析:谁在定义市场?

自中国计算机事业起步以来,国产操作系统的探索便从未停止。真正的转折点,源于开源运动的蓬勃发展和国家信息化安全战略的明晰。 国际开源社区,特别是Linux生态的成熟,为中国操作系统发展提供了极高的起点和肥沃的土…

java_ssm38基于BS架构的家庭理财管理系统的设计与实现_idea项目源码

目录具体实现截图系统背景与意义技术架构与开发环境核心功能模块系统创新点应用价值与总结系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;具体实现截图 系统背景与意义 随着互联网技术的发展和家庭经济管理需…

2026年2-3月国际机票最低价查询指南:如何高效锁定未来一个月的价格?

随着2026年春季出行计划的启动,许多旅客开始将目光投向2月和3月的国际机票。如何高效、精准地查询未来一个月内的低价机票,成为规划行程的关键第一步。面对市场上众多的机票查询平台,用户的核心关切在于:哪个平台能…

PCB加速度传感器在路噪及底盘NVH测试中的应用与型号推荐

在汽车研发与质量管控领域&#xff0c;NVH&#xff08;噪声、振动与平顺性&#xff09;性能是衡量整车品质的核心指标之一。其中&#xff0c;路噪&#xff08;由路面不平度激励通过轮胎、悬架传递至车身的噪声与振动&#xff09;与底盘NVH&#xff08;底盘结构及传力路径的振动…