[XXSY] 构树(prufer序列,树上连通块DP)

传送门

CayleyCayleyCayley公式:一个完全图有nn−2n^{n-2}nn2棵无根生成树(可用prufer序列证明)
扩展CayleyCayleyCayley公式:被确定边分为大小为a1,a2,⋯,ama_1,a_2,\cdots, a_ma1,a2,,am的连通块,则有nm−2∏i=1main^{m-2}\prod\limits_{i=1}^{m}{a_i}nm2i=1mai种生成树

我们强制生成树中的一些边与原树中的边相同,求出生成树中至少xxx条边于原树中边相同的方案数ansxans_xansx,再容斥得到生成树中恰好xxx条边与原树中边相同的方案数AnsxAns_xAnsx

Ansx=∑i=x(−1)i−x(ix)ansiAns_x=\sum\limits_{i=x}(-1)^{i-x}\dbinom{i}{x}ans_iAnsx=i=x(1)ix(xi)ansi

考虑一棵以uuu为根的生成子树,里面有jjj条边强制与原树中边相同。如果只加入强制相同jjj条边,我们会得到若干连通块,即子树被非强制相同的边分成若干连通块,可以用拓展CayleyCayleyCayley公式统计方案数。

nm−2n^{m-2}nm2可以留到最后处理,所以我们只考虑求∏i=1mai\prod\limits_{i=1}^{m}{a_i}i=1mai,其组合意义为每个连通块内各选一个关键点的方案数。

dp[u][j][0/1]dp[u][j][0/1]dp[u][j][0/1]表示以uuu为根的子树内有jjj强制相同的边,uuu所在的连通块选/未选选/未选/关键点选关键点方案数之和。转移如下:

u−vu-vuv强制相同的边(v∈sonuv\in son_uvsonu):
dp[u][j][0]×dp[v][k][0]→dp[u][j+k+1][0]dp[u][j][0]\times dp[v][k][0]\to dp[u][j+k+1][0]dp[u][j][0]×dp[v][k][0]dp[u][j+k+1][0]
dp[u][j][0]×dp[v][k][1]+dp[u][j][1]×dp[v][k][0]→dp[u][j+k+1][1]dp[u][j][0]\times dp[v][k][1]+dp[u][j][1]\times dp[v][k][0]\to dp[u][j+k+1][1]dp[u][j][0]×dp[v][k][1]+dp[u][j][1]×dp[v][k][0]dp[u][j+k+1][1]
u−vu-vuv非强制相同的边(v∈sonuv\in son_uvsonu):
dp[u][j][0]×dp[v][k][1]→dp[u][j+k][0]dp[u][j][0]\times dp[v][k][1]\to dp[u][j+k][0]dp[u][j][0]×dp[v][k][1]dp[u][j+k][0]
dp[u][j][1]×dp[v][k][1]→dp[u][j+k][1]dp[u][j][1]\times dp[v][k][1]\to dp[u][j+k][1]dp[u][j][1]×dp[v][k][1]dp[u][j+k][1]

类似题目:WC2019数树

#include<bits/stdc++.h>
using namespace std;
const int mod=1000000007;
const int N=8010;
int read(){int x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}return x*f;
}
int add(int x,int y){return x+y>=mod?x+y-mod:x+y;}
int dec(int x,int y){return x-y<0?x-y+mod:x-y;}
int mul(int x,int y){return 1ll*x*y%mod;}
void Add(int &x,int y){x=x+y>=mod?x+y-mod:x+y;}
void Dec(int &x,int y){x=x-y<0?x-y+mod:x-y;}
void Mul(int &x,int y){x=1ll*x*y%mod;}
int ksm(int a,int b){if(b<0) return ksm(ksm(a,-b),mod-2);int ans=1;while(b){if(b&1) ans=mul(ans,a);a=mul(a,a);b>>=1;}return ans;
}
int n,fac[N],ifac[N];
int cnt,head[N],nxt[N<<1],to[N<<1],siz[N];
vector<int>f[N],g[N];//f:0,g:1
void adde(int u,int v){to[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;
}
void Clear(vector<int> &v){vector<int>().swap(v);
}
void dfs(int u,int fa){siz[u]=1;f[u].push_back(1);g[u].push_back(1);for(int i=head[u];i;i=nxt[i]){int v=to[i];if(v==fa) continue;dfs(v,u);f[u].resize(siz[u]+siz[v]);g[u].resize(siz[u]+siz[v]);for(int j=siz[u]-1;j>=0;j--){const int fu=f[u][j],gu=g[u][j];f[u][j]=g[u][j]=0;for(int k=siz[v]-1;k>=0;k--){const int fv=f[v][k],gv=g[v][k];Add(f[u][j+k+1],mul(fu,fv));Add(f[u][j+k],mul(fu,gv));Add(g[u][j+k+1],add(mul(fu,gv),mul(gu,fv)));Add(g[u][j+k],mul(gu,gv));}}siz[u]+=siz[v];Clear(f[v]),Clear(g[v]);}
}
int C(int n,int m){return mul(mul(fac[n],ifac[m]),ifac[n-m]);
}
int main(){n=read();for(int i=1;i<n;i++){int u=read(),v=read();adde(u,v),adde(v,u);}dfs(1,0);fac[0]=1;for(int i=1;i<=n;i++) fac[i]=mul(fac[i-1],i);ifac[n]=ksm(fac[n],mod-2);for(int i=n;i>=1;i--) ifac[i-1]=mul(ifac[i],i);for(int i=0;i<n;i++) Mul(g[1][i],ksm(n,n-i-2));for(int i=0;i<n;i++){int ans=0;for(int j=i;j<n;j++){if((j-i)&1) Dec(ans,mul(C(j,i),g[1][j]));else Add(ans,mul(C(j,i),g[1][j]));}printf("%d ",ans);}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319853.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.NET Core中的性能测试工具BenchmarkDotnet

背景介绍之前一篇博客中&#xff0c;我们讲解.NET Core中的CSV解析库&#xff0c;在文章的最后&#xff0c;作者使用了性能基准测试工具BenchmarkDotNet测试了2个不同CSV解析库的性能&#xff0c;本篇我们来详细介绍一下BenchmarkDotNet。原文链接&#xff1a;https://dotnetco…

序列求和

来源&#xff1a;牛客网 文章目录题目描述题解&#xff1a;代码&#xff1a;时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 131072K&#xff0c;其他语言262144K 64bit IO Format: %lld题目描述 定义S(n) 12 22 … n2&#xff0c;输出S(n) …

【区间DP】摆渡线路(2017 特长生 T4)

题目大意 给出一个园&#xff0c;圆上有100个点&#xff0c;若干条弦&#xff0c;让你选择尽量多互不相交的弦&#xff08;点可以重合&#xff09; 解题思路 可以把圆展开成链&#xff0c;然后复制一遍 设fi,jf_{i,j}fi,j​为第i个位置到第j个位置的所选弦的数量 那么可以枚…

bzoj4589-Hard Nim【FWT】

正题 题目链接:https://darkbzoj.tk/problem/4589 题目大意 求有多少个长度为nnn的数列满足它们都是不大于mmm的质数且异或和为000。 解题思路 两个初始多项式F[0]1F[0]1F[0]1&#xff0c;G[prime≤m]1G[prime\leq m]1G[prime≤m]1&#xff0c;然后答案就是FxorGnF\ xor\ G^…

some useful tricks

异或题思考方向&#xff1a;01trie树&#xff0c;分治 2. 二分图最大匹配&#xff0c;最大独立集互相转换 3. Snow 4. Code 5. Code 6. Code 7. 题目 #include<iostream> #include<cstdio> using namespace std; const int N100010; int n,p,nxt[N],no[200]…

25大技术主题向您发出最后一次约【惠】邀请

一年一度的微软技术盛会即将在上海世博中心拉开大幕金秋十月&#xff0c;来自两岸三地的百名明星讲师将携 25 大技术主题&#xff0c;齐聚上海为您奉献一场无与伦比的技术视听盛宴您&#xff0c;准备好了吗&#xff1f;25大技术主题公开&#xff0c;不负期待姗姗来迟的5系25大技…

P4980-[模板]Pólya定理

正题 题目链接:https://www.luogu.com.cn/problem/P4980 题目大意 nnn个物品图上mmm种颜色&#xff0c;求在可以旋转的情况下本质不同的涂色方案。 解题思路 既然是群论基本题就顺便写一下刚刚了解到的相关知识把&#xff08;顺便消磨一下时间 一个群(G,)(G,\times )(G,)定义…

逆元的求法

逆元&#xff1a; 对于a和p&#xff0c;若 a * inv(a) % p ≡ 1&#xff0c;则称inv(a)为a%p的逆元。其中p为质数 逆元就是在mod下&#xff0c;不能直接除以一个数&#xff0c;而要乘以他的逆元 a * inv(a) 1 (mod p) x / a可以改成 x * inv(a) % p 文章目录方法一.扩展欧几里…

[CF995F] Cowmpany Cowmpensation(树形dp,拉格朗日插值)

树形DP&#xff1a; 设f[u][i]f[u][i]f[u][i]表示给uuu的子树分配工资&#xff0c;uuu点工资为iii的方案数 f[u][i]∏v∈sonu(∑j1if[v][j])f[u][i]\prod\limits_{v\in son_u}(\sum\limits_{j1}^{i}f[v][j])f[u][i]v∈sonu​∏​(j1∑i​f[v][j]) 前缀和优化&#xff1a; 设g[u…

【dfs】益智游戏(2017 特长生 T2)

题目大意 给你四个数字&#xff0c;问你能否经过加减乘除使其结果为24 解题思路 先暴力枚举四个数字的全排列&#xff0c;然后枚举运算符和括号 代码 #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #define ll long …

分布式系统消息中间件——RabbitMQ的使用基础篇

前言我是在解决分布式事务的一致性问题时了解到RabbitMQ的&#xff0c;当时主要是要基于RabbitMQ来实现我们分布式系统之间对有事务可靠性要求的系统间通信的。关于分布式事务一致性问题及其常见的解决方案&#xff0c;可以看我另一篇博客。提到RabbitMQ&#xff0c;不难想到的…

P4630-[APIO2018]Duathlon铁人两项【圆方树】

正题 题目链接:https://www.luogu.com.cn/problem/P4630 题目大意 nnn个点mmm条边的一张无向图&#xff0c;求有多少对三元组(s,c,f)(s,c,f)(s,c,f)满足s≠f≠ts\neq f\neq ts​f​t且存在一条从sss到fff的简单路径经过ccc 解题思路 一个比较显然的结论是在一个点双中的三…

小a的旅行计划

来源&#xff1a;牛客网 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 32768K&#xff0c;其他语言65536K 64bit IO Format: %lld文章目录题目描述题解&#xff1a;代码&#xff1a;题目描述 小a终于放假了&#xff0c;它想在假期中去一些地方…

吃豆人(luogu 7472/NOI Online 2021 普及组 T2)

正题 luogu 7472 题目大意 给出一个正方形点阵&#xff0c;让你选择两个点&#xff0c;分别向两个方向移动&#xff08;必须是45度&#xff09;&#xff0c;每到一个点就得到该点的贡献&#xff08;不重复得&#xff09;&#xff0c;遇到墙壁反射&#xff0c;问你最大贡献 解…

[XSY] 选举(线段树优化dp)

选举 //a[i]1 or 0 or -1,表示i支持小奇 or 中立 or 支持魔法猪 //sum[i]a[1]a[2]...a[i] //设dp[i]表示把1~i划分成若干区间,(小奇得票-魔法猪得票)的最大值 /*dp[i]max {dp[j]1 (sum[i]-sum[j]>0即sum[i]>sum[j])dp[j] (sum[i]-sum[j]0即sum[i]sum[j])dp[j]-1 (sum[…

P3480-[POI2009]KAM-Pebbles【阶梯博弈】

正题 题目链接:https://www.luogu.com.cn/problem/P3480 题目大意 nnn个石头堆上进行Nim\text{Nim}Nim游戏&#xff0c;不过需要满足每次操作前后都有ai≤ai1(i∈[1,n))a_i\leq a_{i1}(\ i\in[1,n)\ )ai​≤ai1​( i∈[1,n) ) 解题思路 让每一个biai−ai−1b_ia_i-a_{i-1}bi​…

在 Centos7 用Jexus服务器 运行.Net Core 只需几步

安装 .Net SDK 不需要按照 .net core runtime,sdk 依赖于运行时会自动安装第一步 添加dotnet源sudo rpm -Uvh https://packages.microsoft.com/config/rhel/7/packages-microsoft-prod.rpm第二步 安装 .Net Core可能由于网络原因&#xff0c;下载要耐心等待一段时间,下载完成后…

小球碰撞(理解ing)

来源&#xff1a;牛客网&#xff1a; 文章目录题目描述题解&#xff1a;代码&#xff1a;时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld题目描述 一个弹球&#xff08;可视为质点&am…

【斜率优化】Cats Transport(luogu-CF 311B)

正题 luogu-CF 311B 题目大意 有n个点&#xff0c;p个铲屎官和m只猫 did_idi​表示i到i-1的距离 第i只猫在tit_iti​这个时间hih_ihi​这个点开始等待铲屎官来接它走 铲屎官会以一个单位时间走一个单位长度的速度从第一个点向最后一个点走&#xff08;不能停止&#xff09;&a…

[XSY4170] 妹子(线段树上二分)

传送门 题意&#xff1a; 给出两个长度为NNN的整数序列A1A2...ANA_1A_2...A_NA1​A2​...AN​,B1B2...BNB_1B_2...B_NB1​B2​...BN​。有MMM组询问(opt,l,r,d)(opt,l,r,d)(opt,l,r,d)&#xff0c;令nr−l1nr-l1nr−l1 若optAoptAoptA&#xff1a;∀i∈[1,n],aiAli−1d,biBli−…