P8602 [蓝桥杯 2013 省 A] 大臣的旅费【树的直径】

P8602 [蓝桥杯 2013 省 A] 大臣的旅费 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

cpp 复制代码
#include<iostream>
#include <algorithm>
#include <vector>
using namespace std;
#define int long long
const int N=5e5+100;
int n;
int res=0;
typedef pair<int,int>pii;
vector<pii>g[N];
bool vis[N];
int len=0;
int dfs(int u)
{
    vis[u]=true;
    int d1=0;//d1记录的是u向下能走的最大长度
    int d2=0;//d2记录的是u向下能走的第二的长度
    for(auto i:g[u])
    {
        int v=i.first;
        int w=i.second;
        if(vis[v])//防止往回搜索
            continue;
        int d=dfs(v)+w;
        if(d>d1)//更新最大值与第二大值
            d2=d1,d1=d;
        else if(d>d2)
            d2=d;
    }
    len=max(len,d1+d2);//保存最大的数值
    return d1;//返回最长长度
}
signed main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);cout.tie(nullptr);
    cin>>n;
    for(int i=1;i<=n-1;i++)
    {
        int p,q,d;
        cin>>p>>q>>d;
        g[p].push_back((pii){q,d});
        g[q].push_back((pii){p,d});
    }
    dfs(1);//求树的直径,1是根节点
    int ans=0;
    for(int i=1;i<=len;i++)//计算答案
        ans+=10+i;
    cout<<ans;
    return 0;
}
相关推荐
aini_lovee几秒前
半定规划(SDP)求解的 MATLAB 实现
算法
米粒111 分钟前
力扣算法刷题 Day 41(买卖股票)
算法·leetcode·职场和发展
幻风_huanfeng13 分钟前
人工智能之数学基础:内点法和外点法的区别和缺点
人工智能·算法·机器学习·内点法·外点法
天若有情67315 分钟前
颠覆C++传统玩法!Property属性与伪类,开辟静态语言新维度
java·c++·servlet
MIngYaaa52022 分钟前
The 6th Liaoning Provincial Collegiate Programming Contest - External 复盘
算法
CylMK23 分钟前
题解:P11625 [迷宫寻路 Round 3] 迷宫寻路大赛
c++·数学·算法
计算机安禾35 分钟前
【数据结构与算法】第44篇:堆(Heap)的实现
c语言·开发语言·数据结构·c++·算法·排序算法·图论
kaikaile199538 分钟前
能量算子的MATLAB实现与详细算法
人工智能·算法·matlab
tankeven41 分钟前
HJ175 小红的整数配对
c++·算法
Aaron15881 小时前
数字波束合成DBF与模拟波束合成ABF对比浅析
大数据·人工智能·算法·硬件架构·硬件工程·信息与通信·信号处理