题目
给出一个图,然后每次询问给出敌人攻击值,低于攻击值的边都会被删去,每次询问独立,回答攻击过后还有多少对点连通。
看到连通首先想到并查集,但是问的不是连通块数,是连通块中点的对数,显然如果一个连通块有n个点,那么就有 C n 2 对 点 , G n 2 = ( n − 1 ) n / 2 , 所 以 只 要 稍 微 改 动 一 下 并 查 集 代 码 , 知 道 每 个 连 通 块 点 数 , 就 能 得 到 答 案 。 C_n^2对点,G_n^2=(n-1)n/2,所以只要稍微改动一下并查集代码,知道每个连通块点数,就能得到答案。 Cn2对点,Gn2=(n−1)n/2,所以只要稍微改动一下并查集代码,知道每个连通块点数,就能得到答案。
并查集改动
首先par数组就要改一改,建个结构体数组,f相当于原来的par数组,sum记录连通块点数。
struct Node