八中友好教室2

题目

前置题目

八中友好教室1-CSDN博客

思路

这一题与八中友好教室1差不多,但是题目把"最小"改成了"最大"。

那么很简单,我们只要将每一条边都连一次就行了。

代码

cpp 复制代码
#include<bits/stdc++.h>
#define int long long
using namespace std;
struct node
{
  int u,len;
};
vector<node>vec[1000001];
int ans,zi[1000001],n,x,y,len;
inline int read() {int x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9') {if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9') x=x*10+ch-'0',ch=getchar();return x*f;}
void dfs(int u,int fa)
{
  zi[u] = 1;
  for(int i = 0;i < vec[u].size();i++)
	if(vec[u][i].u != fa)
	{
	  dfs(vec[u][i].u,u);
	  zi[u] += zi[vec[u][i].u];
	  ans += vec[u][i].len * zi[vec[u][i].u];
	}
}
signed main()
{
  cin>>n;
  for(int i = 1;i < n;i++)
  {
	x = read();
    y = read();
    len = read();
	vec[x].push_back({y,len});
	vec[y].push_back({x,len});
  }
  dfs(1,0);
  cout<<ans<<endl;
  return 0;
}
相关推荐
灵感__idea2 小时前
Hello 算法:贪心的世界
前端·javascript·算法
澈2073 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解
数据结构·c++·算法
ambition202423 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
cmpxr_3 小时前
【C】原码和补码以及环形坐标取模算法
c语言·开发语言·算法
qiqsevenqiqiqiqi3 小时前
前缀和差分
算法·图论
代码旅人ing3 小时前
链表算法刷题指南
数据结构·算法·链表
Yungoal4 小时前
常见 时间复杂度计算
c++·算法
不爱吃炸鸡柳5 小时前
单链表专题(完整代码版)
数据结构·算法·链表
CylMK5 小时前
题解:AT_abc382_d [ABC382D] Keep Distance
算法
Dfreedom.5 小时前
计算机视觉全景图
人工智能·算法·计算机视觉·图像算法