小 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$ 之间的电阻就能用串并联方法计算。
集合 $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$