题目描述
输入描述:
输出描述:
示例1
输入
5
4 3
0 1
1 2
2 3
4
0 1 3 0
4 3
0 1
1 2
2 3
2
0 2
4 3
0 1
1 2
2 3
2
0 3
4 1
1 3
1
2
5 5
0 1
0 2
1 2
1 3
3 4
3
4 4 0
输出
0 0 0 0
2 2 2 2
0 0 3 3
0 1 2 3
0 0 0 0 0
说明
题目大意
给定一张n个点,m条边的图。每个点都有各自的颜色1,2,3……n。接下来进行q次染色操作。每次操作给定一个qi,要求把所有的颜色为qi的点的相邻的所有颜色不为qi的点,染色为qi。
分析
题意有点绕,接下来深解一下题意。其实就是对于每个颜色进行一次BFS式的扩展,如图。
首先分析染色的过程,每个点的周边部分被染色的过程就像并查集的过程,把周围的颜色变成这个点的颜色。
所以我们可以定义一个col[],表示每个点的颜色,如果被染色,那就用并查集查找一下它的颜色,然后更改。
但是这样有点问题。就是上图中的第二个图。所有被染色的点都要作为源点进行染色。(样例里面能调出来,太良心了)因此需要一个vector的合并,在染色的同时,把连边的信息也要同时转移过去。
于是这里就要用到一个启发式合并,把小的集合复制到大的集合里去,也叫拍脑瓜合并。
WAWAWA
拒绝骚操作,从我做起。 之前翻大佬代码的时候看到如此操作
for(scanf("%d",&t);t--;)
结果