bzoj#P4016. [FJOI2014]最短路径树问题

[FJOI2014]最短路径树问题

题目描述

给一个包含 nn 个点,mm 条边的无向连通图。从顶点 11 出发,往其余所有点分别走一次并返回。

往某一个点走时,选择总长度最短的路径走。若有多条长度最短的路径,则选择经过的顶点序列字典序最小的那条路径(如路径 AA1,32,111,32,11,路径 BB1,3,2,111,3,2,11,路径 BB 字典序较小。注意是序列的字典序的最小,而非路径中节点编号相连的字符串字典序最小)。到达该点后按原路返回,然后往其他点走,直到所有点都走过。

可以知道,经过的边会构成一棵最短路径树。请问,在这棵最短路径树上,最长的包含 KK 个点的简单路径长度为多长?长度为该最长长度的不同路径有多少条?

这里的简单路径是指:对于一个点最多只经过一次的路径。不同路径是指路径两端端点至少有一个不同,点 AA 到点 BB 的路径和点 BB 到点 AA 视为同一条路径。

输入格式

第一行输入三个正整数 n,mn,mKK,表示有 nn 个点 mm 条边,要求的路径需要经过 KK 个点。

接下来输入 mm 行,每行三个正整数Ai,Bi,Ci(1Ai,Bin,1Ci10000)A_i,B_i,C_i(1\le A_i,B_i\le n,1\le C_i\le 10000),表示 AiA_iBiB_i 间有一条长度为 CiC_i 的边。

数据保证输入的是连通的无向图。

输出格式

输出一行两个整数,以一个空格隔开,第一个整数表示包含K个点的路径最长为多长,第二个整数表示这样的不同的最长路径有多少条。

6 6 4
1 2 1
2 3 1
3 4 1
2 5 1
3 6 1
5 6 1
3 4

数据范围

对于 100%100\% 数据 n30000,m60000n\le 30000,m\le 600002Kn2\le K\le n

数据保证最短路径树上至少存在一条长度为 KK 的路径。