CF671D.Roads in Yusland
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
Mayor of Yusland just won the lottery and decided to spent money on something good for town. For example, repair all the roads in the town.
Yusland consists of n intersections connected by n−1 bidirectional roads. One can travel from any intersection to any other intersection using only these roads.
There is only one road repairing company in town, named "RC company". Company's center is located at the intersection 1 . RC company doesn't repair roads you tell them. Instead, they have workers at some intersections, who can repair only some specific paths. The i -th worker can be paid ci coins and then he repairs all roads on a path from ui to some vi that lies on the path from ui to intersection 1 .
Mayor asks you to choose the cheapest way to hire some subset of workers in order to repair all the roads in Yusland. It's allowed that some roads will be repaired more than once.
If it's impossible to repair all roads print −1 .
输入格式
The first line of the input contains two integers n and m ( 1≤n,m≤300000 ) — the number of cities in Yusland and the number of workers respectively.
Then follow n−1 line, each of them contains two integers xi and yi ( 1≤xi,yi≤n ) — indices of intersections connected by the i -th road.
Last m lines provide the description of workers, each line containing three integers ui , vi and ci ( 1≤ui,vi≤n , 1≤ci≤109 ). This means that the i -th worker can repair all roads on the path from vi to ui for ci coins. It's guaranteed that vi lies on the path from ui to 1 . Note that vi and ui may coincide.
输出格式
If it's impossible to repair all roads then print −1 . Otherwise print a single integer — minimum cost required to repair all roads using "RC company" workers.
输入输出样例
输入#1
6 5 1 2 1 3 3 4 4 5 4 6 2 1 2 3 1 4 4 1 3 5 3 1 6 3 2
输出#1
8
说明/提示
In the first sample, we should choose workers with indices 1 , 3 , 4 and 5 , some roads will be repaired more than once but it is OK. The cost will be equal to 2+3+1+2=8 coins.