news 2026/4/23 6:47:28

Atcoder[ABC401F] Add One Edge 3 题解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Atcoder[ABC401F] Add One Edge 3 题解

[ABC401F] Add One Edge 3

思路

设第一棵树的直径长度为l 1 l1l1,第二棵树的直径长度为l 2 l2l2a i a_iai为第一棵树中以点i ii为端点的路径的长度最大值,b i b_ibi为第二棵树中以点i ii为端点的路径的长度最大值。则f ( i , j ) f(i,j)f(i,j)有两种情况:

  1. 经过边( i , j ) (i,j)(i,j)a i + b j + 1 a_i+b_j+1ai+bj+1
  2. 不经过边( i , j ) (i,j)(i,j)max ⁡ ( l 1 , l 2 ) \max (l1,l2)max(l1,l2)

两种情况取较大值即可。

根据直径的性质,a i a_iaib i b_ibi一定经过直径的其中一个端点,故在求直径的时候可以顺便求出a i a_iaib i b_ibi

我们将a aab bb排序。对于每个i ii,可以二分/双指针求出b i + a i ≤ max ⁡ ( l 1 , l 2 ) b_i+a_i\le \max (l1,l2)bi+aimax(l1,l2)b i b_ibiO ( 1 ) O(1)O(1)快速计算答案。

代码

时间复杂度O ( n log ⁡ n ) O(n\log_{}{n} )O(nlogn),瓶颈在于排序。
注意到可以使用桶排序,时间复杂度O ( n ) O(n)O(n)

#include<bits/stdc++.h>usingnamespacestd;constintN=2e5+5;vector<int>e[N];intn,k,a[N],b[N],dep[N],fa[N];voiddfs(intx){dep[x]=dep[fa[x]]+1;if(dep[x]>dep[k])k=x;for(inti=0;i<e[x].size();i++)if(e[x][i]!=fa[x]){fa[e[x][i]]=x;dfs(e[x][i]);}}boolbj[N];intl[N],cnt;voiddfss(intx,inty)//求a,b{a[x]=y,bj[x]=1;for(inti=0;i<e[x].size();i++)if(e[x][i]!=fa[x]&&!bj[e[x][i]]){fa[e[x][i]]=x;dfss(e[x][i],y+1);}}intsolve(){cin>>n;for(inti=1;i<n;i++){intu,v;cin>>u>>v;e[u].push_back(v),e[v].push_back(u);}memset(bj,0,sizeof(bj));k=cnt=fa[1]=0;dfs(1);intkkk=k;k=fa[kkk]=0;dfs(kkk);while(k)l[++cnt]=k,bj[k]=1,k=fa[k];//求直径for(inti=1;i<=cnt;i++){fa[l[i]]=0;dfss(l[i],max(i-1,cnt-i));}for(inti=1;i<=n;i++)e[i].clear();returncnt-1;}inttong[N];voidsor()//神秘桶排序{memset(tong,0,sizeof(tong));for(inti=1;i<=n;i++)tong[a[i]]++;intcnt=0;for(inti=1;i<=2e5;i++)while(tong[i]--)a[++cnt]=i;}intmain(){ios::sync_with_stdio(0);cin.tie(0),cout.tie(0);intl1=solve(),m=n;sor();for(inti=1;i<=n;i++)b[i]=a[i];intl2=solve();sor();intnow=0;longlongans=0,sum=0;for(inti=1;i<=m;i++)sum+=b[i]+1;for(inti=n;i>=1;i--)//注意枚举顺序{while(now+1<=m&&b[now+1]+1+a[i]<=max(l1,l2))now++,sum-=b[now]+1;ans+=now*1ll*max(l1,l2);ans+=sum+1ll*(m-now)*a[i];}cout<<ans;return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 22:09:53

Java毕设项目推荐-基于vue的宠物之家管理系统基于springboot的宠物店管理系统【附源码+文档,调试定制服务】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/19 20:25:21

欧姆龙 Omron PLC 系列 NX/NJ 编程实战:ST 与功能块应用

欧姆龙OmronPLC系列NX/NJ。 程序事例参考。 包括ETHERCAT伺服通讯的FB功能块&#xff0c;气缸控制的FB功能块。 ST编程。 Sysmac Studio。在自动化控制领域&#xff0c;欧姆龙 Omron PLC 系列的 NX/NJ 以其强大的性能和丰富的功能备受关注。今天咱就聊聊如何基于 Sysmac Studio…

作者头像 李华
网站建设 2026/4/17 22:09:12

DeFi 2.0流动性革命:动态博弈算法如何重构万亿级质押经济?

引言&#xff1a;流动性困局与DeFi 2.0的破局之道2020年“DeFi Summer”的狂欢中&#xff0c;流动性挖矿以高收益点燃了加密市场&#xff0c;但随之而来的“流动性吸血鬼”效应却让协议陷入恶性循环——早期用户通过通胀代币套利离场&#xff0c;留下协议因流动性枯竭而衰败。这…

作者头像 李华