HDU - 5739
给定一张无向图,每个点有个点权
一个图的权值计算为,现将同一联通分量的点权相乘
再将不同联通分量的点权相加
求图割去一个点后的权值
其中对于哪些非关节点,权值比较好计算
而对于关节点,割去之后图比较复杂
所以要用到一个叫做 Block Forest Data Structure的建图方式
首先求出图中的点双联通分量,
对于每一个点双,新建一个点向其中所有点连边
新图就会变成一个森林,其中非关节点是叶子节点,
而关节点和新建的点是内点
然后用树形统计一下每个点儿子的乘积和以及子树的乘积和
有一个trick就是有孤点的情况,孤点不会被记入点双,
所以特判一下,对于孤点直接计算答案即可
#pragma comment(linker, "/STACK:102400000,102400000")
#include <cstdio>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cctype>
#include <map>
#include <set>
#include <queue>
#include <bitset>
using namespace std;
typedef pair<int,int> Pii;
typedef long long LL;
typedef unsigned long long ULL;
typedef double DBL;
typedef long double LDBL;
#define MST(a,b) memset(a,b,sizeof(a))
#define CLR(a) MST(a,0)
#define SQR(a) ((a)*(a))
#define PCUT puts("----------")
const int maxn=2e5+10, maxm=2e5+10;