prufer编码
看51nod的一场比赛,发现不会大家都A的一道题,有关prufer的
我去年4月就埋下prufer这个坑,一直没解决
prufer编码是什么
对于一棵无根树的生成的序列,prufer序列可以和无根树一一对应,具体可以参见百科和poj2567和poj2568两个题。
prufer序列用来计数
- \(n\) 个点的无向完全图的生成树的个数为 \(n^{n-2}\) 。即prufer序列的长度为 \(n-2\),每个点的值是1 到 \(n\)
- \(n\) 个节点的度依次为 \(D_1\),\(D_2\),...,\(D_n\) 的无根树共有 \(\dfrac{(n-2)!}{\prod{(D_i-1)!}}\)。即第 \(i\) 个点出现了 \(D_i-1\) 次,变转换成问题:\(n\) 种元素,共 \(n-2\) 个,其中第 \(i\) 种元素有 \(D_i-1\) 个,求排列数。
- \(n\) 个节点的度数有的已知有的未知,假设有 \(m\) 个未知的,\(L=n-2-\sum{(D_i-1)}\) ,那么树的个数为 \(\dfrac{m^L(n-2)!}{L!\prod{(D_i-1)!}}\) ,参见
bzoj1005。
51nod1805
大意:\(n\) 个点生成的树,\(m\) 个叶子节点的方案数,\(n\leq 10^6\)
考虑这棵树的prufer序列,那么问题转化为长度为 \(n-2\) ,且在着 \(n-2\) 个数里面恰好出现了 \(n-m\) 个不同的数的方案数,就可以容斥一下解决了
inline int pw(int n,int m){int r=1;for(;m;m>>=1,n=1ll*n*n%MOD)if(m&1)r=1ll*r*n%MOD;return r;}
const int N=1e6+1;
int n,m,fac[N],fai[N];
void init(){
fac[0]=1;For(i,1,N)fac[i]=1ll*fac[i-1]*i%MOD;
fai[N-1]=pw(fac[N-1],MOD-2);
per(i,1,N-1)fai[i-1]=1ll*fai[i]*i%MOD;
}
inline int C(int n,int m){return 1ll*fac[n]*fai[m]%MOD*fai[n-m]%MOD;}
int main(){
init();
n=rd(),m=rd();
if(n==2&&m==2){puts("1");return 0;}
ll ans=0;
per(i,1,(n-m)){
ans+=((n-m-i&1)?-1ll:1ll)*C(n-m,i)*pw(i,n-2)%MOD;
}
ans=(ans%MOD+MOD)%MOD;
ans=ans*C(n,n-m)%MOD;
cout<<ans<<endl;
}
prufer编码的更多相关文章
- 树的prufer编码
prufer是无根树的一种编码方式,一棵无根树和一个prufer编码唯一对应,也就是一棵树有唯一的prufer编码,而一个prufer编码对应一棵唯一的树. 第一部分:树编码成prufer序列. 树编 ...
- 【转】prufer编码
既然有人提到了,就顺便学习一下吧,来源:http://greatkongxin.blog.163.com/blog/static/170097125201172483025666/ 一个含有n个点的完 ...
- [BZOJ1430] 小猴打架 (prufer编码)
Description 一开始森林里面有N只互不相识的小猴子,它们经常打架,但打架的双方都必须不是好朋友.每次打完架后,打架的双方以及它们的好朋友就会互相认识,成为好朋友.经过N-1次打架之后,整个森 ...
- Codeforces 1109D. Sasha and Interesting Fact from Graph Theory 排列组合,Prufer编码
原文链接https://www.cnblogs.com/zhouzhendong/p/CF1109D.html 题意 所有边权都是 [1,m] 中的整数的所有 n 个点的树中,点 a 到点 b 的距离 ...
- 图论:Prufer编码-Cayley定理
BZOJ1430:运用Cayley定理解决树的形态统计问题 由Prufer编码可以引申出来一个定理:Cayley 内容是不同的n结点标号的树的数量为n^(n-2) 换一种说法就是一棵无根树,当知道结点 ...
- 图论:Prufer编码
BZOJ1211:使用prufer编码解决限定结点度数的树的计数问题 首先学习一下prufer编码是干什么用的 prufer编码可以与无根树形成一一对应的关系 一种无根树就对应了一种prufer编码 ...
- [bzoj1005][HNOI2008]明明的烦恼-Prufer编码+高精度
Brief Description 给出标号为1到N的点,以及某些点最终的度数,允许在 任意两点间连线,可产生多少棵度数满足要求的树? Algorithm Design 结论题. 首先可以参考这篇文章 ...
- BZOJ 1430 小猴打架(prufer编码)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1430 [题目大意] 一开始森林里面有N只互不相识的小猴子,它们经常打架, 但打架的双方 ...
- 【Foreign】树 [prufer编码][DP]
树 Time Limit: 10 Sec Memory Limit: 256 MB Description Input Output Sample Input 3 2 2 1 Sample Outp ...
随机推荐
- linux下的抓包
1. 查看网卡名字 cat /proc/net/dev 2.抓取外网进来的包 tcpdump -i eth0 port -s -w .pcap 3.抓取自己服务器上的两个程序之间访问的数据 换成 lo ...
- 集腋成裘-03-css基础-02
1.1 三种写法 内嵌式:样式只作用于当前文件,没有真正实现结构表现分离 外链式:作用范围是当前站点,真正实现了内容与表现分离 行内样式:仅限于当前标签,结构混在一起 1.2 标签分类 1.2.1 块 ...
- react-native 之gradle-2.x-all.zip 下载缓慢或失败
去官网http://www.gradle.org/downloadshttp://services.gradle.org/distributions下载匹配的 Gradle 版本把zip直接放到C:\ ...
- Nginx 提示host not found in upstream 错误解决方法
Nginx DNS resolver配置实例,本文讲解在proxy_pass 和 upstream server 通信的时候需要手动指定 resolver,本文就给出了配置实例. nginx 通过 ...
- 解决OS睡眠功能中,移动鼠标就会唤醒
设备管理器,在相应项目上右键属性.
- [转] ES6展开运算符
语法 用于函数调用 myFunction(...iterableObj); 用于数组字面量 [...iterableObj, 4, 5, 6] 函数传参 目前为止,我们都是使用Function.pro ...
- Ncurses - Panel
当你需要创建许多窗口时,你很快就会发现它们会变得难以管理.Panel library提供了很好的解决方案. Panel 实际上是一个窗口,通过容器 - 栈 来管理,栈顶的 panel 是完全可见的,其 ...
- bzoj4520【CQOI2016】K远点对
题解: kd-tree裸题 对每个点维护最近的k个开个堆维护一下
- 使用spark操作kudu
Spark与KUDU集成支持: DDL操作(创建/删除) 本地Kudu RDD Native Kudu数据源,用于DataFrame集成 从kudu读取数据 从Kudu执行插入/更新/ upsert ...
- TopCoder SRM502 Div1 500 贪心 01背包
原文链接https://www.cnblogs.com/zhouzhendong/p/SRM502-500.html SRM502 Div1 500 好题. 首先,如果已经确定了解决所有问题的优先级, ...