#P4787. [BalkanOI2018] Minmaxtree
[BalkanOI2018] Minmaxtree
题目描述
翻译自 BalkanOI 2018 Day1 T3「Minmaxtree」
有一棵有 个结点的无权树,结点分别编号为 。现在要给每条边赋一个权值,使之变为一棵带权树。这棵带权树满足 个条件,条件分为两类:
- 从结点 到结点 的链上最大的边权为 ;
- 从结点 到结点 的链上最小的边权为 。
保证这 组条件的 互不相同。
请构造出这棵树,并输出每条边的边权。
输入格式
第一行有一个整数 。
在接下来的 行中,每行两个整数,表示一条边连接的两个结点。
第 行有一个整数 。
在接下来的 行中,每行开头有一个字母,字母为 或 ,接下来有三个整数 。
输出格式
输出 行,每行三个整数 ,用空格分隔,表示带权树的一条带权边。
4
1 2
2 3
3 4
3
M 1 2 1
m 1 4 0
M 2 3 100
3 2 100
1 2 1
4 3 0
提示
子任务 #1(7 分):;
子任务 #2(22 分):只有条件 1,没有条件 2。
子任务 #3(29 分):所有条件 1 中给出的 到 的链互不相交;所有条件 2 中给出的 到 的链也互不相交。
子任务 #4(42 分):没有其他限制。
对于所有数据,,。
感谢 Planet6174 提供的翻译