#2094. 「ZJOI2016」电阻网络

内存限制:256 MiB 时间限制:1000 ms 标准输入输出
题目类型:传统 评测方式:文本比较
上传者: 匿名

题目描述

小 Y 是一个充满智慧的女孩子,但是她只会使用串并联的方法计算两个节点之间的电阻。

现在小 Y 有一个电阻网络,问有多少点对 u, v \ (u \neq v) 之间的电阻可以用串并联的方法计算出来。

我们来形式化地定义一下点对 u, v \ (u \neq v) 之间的电阻能用串并联的方法计算出来的条件。首先我们把电阻网络看成一个 n 个点 m 条边的图(每个电阻对应一条边)。令 S 表示从 u v 的所有简单路径(不经过重复的点的路径)上点的并集,也就是对于一个点 x ,如果存在一条从 u v 的简单路径经过这个点,那么它就在集合 S 中。如果 S 非空且 S 的导出子图是 u,v 为端点的二端串并联图,那么 u,v 之间的电阻就能用串并联方法计算。

  1. 一个有两个不同端点 s,t 的图被称为二端图,其中一个称为源点,另一个称为汇点。

  2. 两个二端图 X,Y 并联 (parallel composition) 是指建一个新图,把 X Y 的源点和汇点分别合并起来。

  3. 两个二端图 X,Y 串联 (series composition) 是指建一个新图,把 X 的汇点和 Y 的源点合并起来。

  4. 由若干个两个点一条边的二端图经过一系列串并联变化之后形成的图称为二端串并联图。

集合 S 的导出子图点集为 S ,边集由原图中两个端点都在 S 中的边构成。

输入格式

第一行包含两个正整数 n,m ,表示电阻网络中的节点数和电阻数。

接下来 m 行,每行包含两个正整数 u,v \ (1 \leq u,v \leq n, \ u \neq v) ,表示有一个电阻在节点 u v 之间。

输出格式

输出共一行,表示答案,即有多少点对之间的电阻可以使用串并联的方法计算出来。

样例

样例输入

6 6
1 2
1 3
1 4
2 3
2 4
5 6

样例输出

6

样例解释

可行的点对有 (1,2),(1,3),(1,4),(2,3),(2,4),(5,6)

数据范围与提示

对于所有的数据, n,m \leq 10^5