博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj4784【zjoi2017】仙人掌
阅读量:4968 次
发布时间:2019-06-12

本文共 1867 字,大约阅读时间需要 6 分钟。

题目描述

如果一个无自环无重边无向连通图的任意一条边最多属于一个简单环,我们就称之为仙人掌。所谓简单环即不经过
重复的结点的环。
现在九条可怜手上有一张无自环无重边的无向连通图,但是她觉得这张图中的边数太少了,所以她想要在图上连上
一些新的边。同时为了方便的存储这张无向图,图中的边数又不能太多。经过权衡,她想要加边后得到的图为一棵
仙人掌。不难发现合法的加边方案有很多,可怜想要知道总共有多少不同的加边方案。两个加边方案是不同的当且
仅当一个方案中存在一条另一个方案中没有的边。

输入格式

多组数据,第一行输入一个整数T表示数据组数。
每组数据第一行输入两个整数n,m,表示图中的点数与边数。
接下来m行,每行两个整数u,v(1≤u,v≤n,u!=v)表示图中的一条边。保证输入的图
联通且没有自环与重边
Sigma(n)<=5*10^5,m<=10^6,1<=m<=n*(n-1)/2

输出格式

对于每组数据,输出一个整数表示方案数,当然方案数可能很大,请对998244353取模后
输出。

  • 题解:

    • 由于环上的边无法再被另外的环覆盖,所以把所有的环拆掉得到森林;
    • 计算每颗树的$ans$乘起来;
    • $f[u]$表示以$u$为根的子树的方案,$g[u]$表示以$u$为根的子树并且还有某个点可以向上连边的方案;
    • 由于根也可以向上连,$g[u]$是包含$f[u]$的;
    • $f[u]$的递推可以将所有的儿子$v$的$g[v]$乘起来,在乘以儿子之间的互相连边或和$u$连边的方案数;
    • $h[i]$表示$i$个儿子时互相连边的方案:
    • $h[i] = h[i-1] + h[i-2]*(i-1)$;
    • $tot$表示$u$的儿子的个数:
    • $f[u] = \Pi_{v}g[v] * h[tot]$;
    • $u$的子树向上连边可以由$u$或者$u$的一个儿子$v$的子树向上连边;
    • $g[u] = f[u] + tot * \Pi_{v}g[v] h[tot-1] = \Pi_{v}g[v]*h[tot+1]$;
    • 我一直在纠结不连边的方案去哪了?其实不连边的方案数在统计$v$向上连到$u$时被统计了;
  • 1 #include
    2 using namespace std; 3 const int N=1000010,mod=998244353; 4 char gc(){ 5 static char*p1,*p2,s[1000000]; 6 if(p1==p2)p2=(p1=s)+fread(s,1,1000000,stdin); 7 return(p1==p2)?EOF:*p1++; 8 } 9 int rd(){10 int x=0;char c=gc();11 while(c<'0'||c>'9')c=gc();12 while(c>='0'&&c<='9')x=(x<<1)+(x<<3)+c-'0',c=gc();13 return x;14 }15 int T,n,m,vis[N],bl[N],dfn[N],low[N],idx,fg,ans,st[N],top,o,hd[N],cnt,f[N],g[N],h[N],d[N];16 struct Edge{
    int v,nt;}E[N<<1];17 inline void adde(int u,int v){18 E[o]=(Edge){v,hd[u]};hd[u]=o++;19 E[o]=(Edge){u,hd[v]};hd[v]=o++;20 }21 void tarjan(int u,int fa){22 if(fg)return;23 dfn[st[++top]=u]=low[u]=++idx;24 int tot=0;25 for(int i=hd[u],v;i;i=E[i].nt){26 v=E[i].v;27 if(v==fa)continue;28 if(dfn[v=E[i].v]){29 if(d[v])continue;30 if(dfn[v]
    bzoj4784

     

 

转载于:https://www.cnblogs.com/Paul-Guderian/p/10306388.html

你可能感兴趣的文章
简易爬虫(爬取本地数据)
查看>>
Javascript 有用参考函数
查看>>
点群的判别(三)
查看>>
GNSS 使用DFT算法 能量损耗仿真
查看>>
【转】Simulink模型架构指导
查看>>
MYSQL数据库的导出的几种方法
查看>>
SQL Server-5种常见的约束
查看>>
硬件之美
查看>>
[转载]java开发中的23种设计模式
查看>>
表格的拖拽功能
查看>>
函数的形参和实参
查看>>
【TP SRM 703 div2 500】 GCDGraph
查看>>
MapReduce 重要组件——Recordreader组件 [转]
查看>>
webdriver api
查看>>
apache 实现图标缓存客户端
查看>>
揭秘:黑客必备的Kali Linux是什么,有哪些弊端?
查看>>
linux系统的远程控制方法——学神IT教育
查看>>
springboot+mybatis报错Invalid bound statement (not found)
查看>>
Linux环境下SolrCloud集群环境搭建关键步骤
查看>>
P3565 [POI2014]HOT-Hotels
查看>>