bzoj#P3706. 反色刷

反色刷

题目描述

给一张无向图,边有黑白两种颜色,现在你有一堆反色刷,可以从任意点开始刷,经过若干条边后回到起点。 现在要询问至少需要多少个反色刷可以使这张图所有边都变成白色。 因为某种原因,边的颜色是会改变的,于是。。 需要支持以下操作: 1 x  把第x条边反色(编号从0~m-1) 2   询问当前图中最少需要多少个反色刷

输入格式

第一行两个整数n m表示这张图有n个点m条边 接下来m行 每行3个整数 u v c表示一条无向边和这条边的颜色(0为白色 1为黑色) 接下来一个整数q 表示有q个操作 接下来q行为操作 描述如上

输出格式

对于每个询问 输出一行一个整数 表示最少需要的反色刷个数 如果没有合法方案输出-1

6 6
1 2 1
2 3 1
1 3 1
4 5 1
5 6 1
4 6 1
14
2
1 0
2
1 1
1 2
2
1 3
1 4
1 5
2
1 3
1 4
1 5
2

2
-1
1
0
1

提示

100%  n,m,q <= 1000000, c < 2,没有重边自环

题目来源

没有写明来源