atcoder#APC001F. XOR Tree
XOR Tree
题目描述
頂点の木が与えられます。頂点には から の番号がついています。 辺は から までの番号がついていて、辺 は頂点 と をつなぎ、また という値を保持しています。 あなたは以下の操作を何回でもすることが出来ます:
- ある単純pathとある非負整数 を選び、そのpathを構成する各辺 について、 (⊕ は xor)と変化させる。
目標はすべての辺 について とすることです。 目標を達成するために必要な最小の操作回数を求めてください。
输入格式
入力は以下の形式で標準入力から与えられる。
输出格式
目標を達成するために必要な操作回数の最小値を出力せよ。
题目大意
题目描述
给一棵有 个节点的树,节点编号从 到 , 树边编号从 到 。第 条边连接节点 和 ,其权值为 。
你可以对树执行任意次操作,每次操作选取一条链和一个非负整数 ,将链上的边的权值与 异或成为该边的新权值。
问最少需要多少次操作,使得所有边的权值都为 。
输入格式
第一行有 个整数,代表树的节点数 。
接下来 行,每行有 个整数,第 行上的整数分别代表第 条边的参数 。
输出格式
仅一行 个整数,即最小操作数。
数据范围与说明
- 保证给定的图是一棵树
- 保证输入数据都是整数
5
0 1 1
0 2 3
0 3 6
3 4 4
3
2
1 0 0
0
提示
制約
- 与えられるグラフは木
- 入力は全て整数
Sample Explanation 1
以下のようにして三回で目標を達成できます。 - まず、頂点 を結ぶ path に対して で操作する - 次に、頂点 を結ぶ path に対して で操作する - 最後に、頂点 を結ぶ path に対して で操作する