梭净挟 发表于 2025-6-4 08:41:36

CF773D Perishable Roads

思路:

注意到答案应该是链加上一串贡献相同的树的贡献,因为若 \(a \to u\) 的贡献 比 \(b \to u\) 的贡献小,那么可以连 \(b \to a\),答案会更优。
那么有一个贪心思路,对于每个根,找到连向这个根的最短边,然后对于这条边的另一个端点,也找到连向这个端点的最短边,以此类推;很显然,这个假了。
设 \(T\) 为当前根,考虑找到全局最短边 \((u,v,w)\),考虑令 \(u \to T\),然后其它所有点都连 \(v\),这样其它点到 \(T\) 的贡献必然是最小的,但是若 \(u \to T\) 的贡献非常大,那这样也是不优的。
则考虑组成一个 \(u \to T\) 的一条链,使得这条链的贡献加上其它所有点的贡献最优,设 \(d_T\) 表示从 \(u\) 到 \(T\) 组成的链的贡献的最小值,\(x\) 为 \(u \to T\) 除 \(T\) 以外的点的个数。
则贡献为 \(d_T + (n-x-1) w\),发现这个 \(x\) 很烦,考虑去掉,即我们计算 \(d\) 的时候,对于全局边都减去一个 \(w\),则 \(d_T' = d_T - x \times w\) 了。
此时贡献为 \(d_T + (n-1)w\),则我们要求出 \(d_T\) 的最小值,发现是个单源最短路问题,直接跑 dijkstra 即可。
时间复杂度为 \(O(N^2)\)。
完整代码:

#include#define Add(x,y) (x+y>=mod)?(x+y-mod):(x+y)#define lowbit(x) x&(-x)#define pi pair#define pii pair#define iip pair#define ppii pair#define fi first#define se second#define full(l,r,x) for(auto it=l;it!=r;it++) (*it)=x#define Full(a) memset(a,0,sizeof(a))#define open(s1,s2) freopen(s1,"r",stdin),freopen(s2,"w",stdout);#define For(i,l,r) for(register int i=l;i=l;i--)using namespace std;typedef double db;typedef unsigned long long ull;typedef long long ll;bool Begin;const ll N=2020,INF=1e18;inline ll read(){    ll x=0,f=1;    char c=getchar();    while(c'9'){      if(c=='-')          f=-1;      c=getchar();    }    while(c>='0'&&c

龙正平 发表于 2025-12-22 15:21:39

东西不错很实用谢谢分享

狭踝仇 发表于 2025-12-25 16:46:31

感谢分享,学习下。

笙芝 发表于 2026-1-9 16:01:12

感谢分享

晦险忿 发表于 2026-1-14 05:37:57

感谢,下载保存了

时思美 发表于 2026-1-15 15:16:04

这个有用。

曲愍糙 发表于 2026-1-17 16:23:23

收藏一下   不知道什么时候能用到

皇甫佳文 发表于 2026-1-17 23:03:22

分享、互助 让互联网精神温暖你我

赫连如冰 发表于 2026-1-18 08:06:53

谢谢分享,试用一下

尚腱埂 发表于 2026-1-19 02:49:23

yyds。多谢分享

匣卒 发表于 2026-1-19 06:31:32

感谢发布原创作品,程序园因你更精彩

庾芷秋 发表于 2026-1-21 11:56:29

感谢分享,下载保存了,貌似很强大

南宫玉英 发表于 2026-1-21 13:23:18

感谢分享,下载保存了,貌似很强大

济曝喊 发表于 2026-1-23 04:26:11

东西不错很实用谢谢分享

厥轧匠 发表于 2026-1-23 06:35:21

懂技术并乐意极积无私分享的人越来越少。珍惜

愿隙 发表于 2026-1-24 14:00:51

新版吗?好像是停更了吧。

里豳朝 发表于 2026-2-6 01:21:59

yyds。多谢分享

乃阕饯 发表于 2026-2-6 04:10:06

鼓励转贴优秀软件安全工具和文档!

屠焘 发表于 2026-2-7 09:02:34

谢谢分享,试用一下

师悠逸 发表于 2026-2-8 09:16:43

yyds。多谢分享
页: [1] 2
查看完整版本: CF773D Perishable Roads