解题思路:

注意事项:

参考代码:

import java.util.ArrayList;

import java.util.List;

import java.util.Scanner;


public class Main {

    static int n;

    static List<Node>[] g;//定义一个存放了node节点的邻接表 比起领接矩阵更加节省空间

    static long max = -10000000;

    static int pnt = 1;//记录端点

public static void main(String[] args) {

Scanner sc = new Scanner(System.in);

n = sc.nextInt();//城市数

g = new List[n + 1];

for (int i = 1; i <= n; i++) {

g[i] = new ArrayList<Main.Node>();//初始化邻接表的每一个list

}

//规定了只有n - 1条路径

for (int i = 0; i < n - 1; i++) {

int a = sc.nextInt();

int b = sc.nextInt();

int c = sc.nextInt();

g[a].add(new Node(b,c));//在编号为a的链表上添加所能到达的编号以及距离所组成的节点

g[b].add(new Node(a,c));//对称性

}

//以1为根 找到端点

//先从任意一点P出发,找离它最远的点Q,再从点Q出发,找离它最远的点W,W到Q的距离就是是的直径

dfs(2, 2, 0);

dfs(pnt, pnt, 0);

System.out.println(dis2Money(max));


}

//from记录了从哪个点来

public static void dfs(int from,int num,long dis) {

boolean ifLeaf = true;//先假设他就是叶子节点

List<Node> neighbours = g[num];//num节点的邻居

for (int i = 0; i < neighbours.size(); i++) {

Node neighbour = neighbours.get(i);//其中一个邻居

if(neighbour.num == from)continue;

//走到这说明除了父节点还有邻居

ifLeaf = false;

dfs(num, neighbour.num, dis + neighbour.dis);

}

if (ifLeaf && dis > max) {//是叶子节点

max = dis;

pnt = num;

}

}

//推算过程 公差为d的等差数列n项和为 首项a1 加 尾项 (a1 + a1 + (n - 1) * d ) * n / 2  

public static long dis2Money(long dis) {

return 11 * dis + dis * (dis - 1) / 2;

}

static class Node{

int num;

long dis;

public Node(int num, long dis) {

super();

this.num = num;

this.dis = dis;

}

}


}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论