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;
}
相关推荐
MATLAB代码顾问13 小时前
Python实现蜂群算法优化TSP问题
开发语言·python·算法
代码飞天13 小时前
机器学习算法和函数整理——助力快速查阅
人工智能·算法·机器学习
jiushiapwojdap13 小时前
LU分解法求解线性方程组Matlab实现
数据结构·其他·算法·matlab
笨笨饿13 小时前
69_如何给自己手搓一个串口
linux·c语言·网络·单片机·嵌入式硬件·算法·个人开发
纽扣66714 小时前
【算法进阶之路】链表进阶:删除、合并、回文与排序全解析
数据结构·算法·链表
消失的旧时光-194314 小时前
统一并发模型:线程、Reactor、协程本质是一件事(从线程到协程 · 第6篇·终章)
java·python·算法
智者知已应修善业14 小时前
【51单片机不用数组动态数码管显示字符和LED流水灯】2023-10-3
c++·经验分享·笔记·算法·51单片机
AI进化营-智能译站15 小时前
ROS2 C++开发系列16-智能指针管理传感器句柄|告别ROS2节点内存泄漏与野指针
java·c++·算法·ai
报错小能手15 小时前
好好讲讲移动构造 移动赋值
c++
syker16 小时前
AIFerric深度学习框架:自研全栈AI基础设施的技术全景
开发语言·c++