题目链接
题目描述
A network administrator manages a large network. The network consists of N computers and M links between pairs of computers. Any pair of computers are connected directly or indirectly by successive links, so data can be transformed between any two computers. The administrator finds that some links are vital to the network, because failure of any one of them can cause that data can’t be transformed between some computers. He call such a link a bridge. He is planning to add some new links one by one to eliminate all bridges.
You are to help the administrator by reporting the number of bridges in the network after each new link is added.
输入描述:
The input consists of multiple test cases. Each test case starts with a line containing two integers N and M.
Each of the following M lines contains two integers A and B ( ), which indicates a link between computer A and B. Computers are numbered from 1 to N. It is guaranteed that any two computers are connected in the initial network.
The next line contains a single integer ( ), which is the number of new links the administrator plans to add to the network one by one.
The i-th line of the following Q lines contains two integer A and B , which is the i-th added new link connecting computer A and B.
The last test case is followed by a line containing two zeros.
输出描述:
For each test case, print a line containing the test case number( beginning with 1) and Q lines, the i-th of which contains a integer indicating the number of bridges in the network after the first i new links are added. Print a blank line after the output for each test case.
示例1
输入
输出
首先纪念下这道题:
过题的过程比较艰辛(太菜了)
题意:
给出一个n个点n条边的图,有q次操作加询问,每次加入一条边,并询问加入这一条边之后的图中的桥的数量
思路:
偏向总结向,需要完美思路自行跳转下方
wa 30%的做法:
在这道题目中,遇到重边不可能是桥,所以说在建立边的时候,用标记,来维护那些便被标记,然后每次暴力跑[这里就注定了无法ac],统计桥的数量,如果说加入的边是被标记过的,那么说这条边就不再是桥,就将答案-1,看上去似乎是可行的,其实不对,👇
wa_code tle 80%的做法:
在跑的过程中就应该在这个条件的基础上加入另一个条件:当前边是不是重边,重边肯定不是桥
所以这样就不用每次判断加入的边是不于是重边
这里过了大部分的数据,但是还是太年轻了,加入的边影响的可能不仅仅是小规模的图中的较为相邻的节点,有时候加入的边会影响很多个部分,而且只是适用于数据范围较小的情况,👇
ac 100%的做法:
我们应该清楚地了解过一个叫做强连通分量的概念:
如果一个有向图中,存在一条回路,所有的结点至少被经过一次,这样的图为强连通图。在强连通图的基础上加入一些点和路径,使得当前的图不在强连通,称原来的强连通的部分为强连通分量。
在这里我们求出边双连通分量:不存在割边的强连通分量成为边双连通分量
图片来源
因为图中存在桥,所以说我们直接求出边双连通分量并统计出数量在这里我们记作,开始的时候桥的数量是,并且桥的数量就是缩点之后边的数量。对于一个边双联通分量,我们将其看成一个点,那么这整张图就变成了一棵树,所以说就把图上的操作变成了树上的操作
对于每一次的操作,我们可以很清楚的了解到:
- 对于加入的一条边如果说这条边的两个端点在同一个边双联通分量里面,就不会对答案产生影响,那么说我们就不需要考虑对加入的这条边进行操作
- 如果说加入的这条边不在同一个边双联通分量里面,那么就可以说加入这条边之后,两点所在块之间的最短路径上的所有边都不再是桥,所以说就可以用来进行操作,两个端点向祖先点跳,并标记沿途的边[考虑优化]
ac_code