题目描述

给定一个\(DAG\),问这个\(DAG\)有多少种拓扑序。

题解

我们首先需要设计一个能够比较好的转移的状态。

我们可以设\(dp[i][j]\)表示第i个点在当前\(dp\)的子图中拓扑排名为\(j\)的方案数。

至于\(dp\)的方式,我们发现只有\(n-1\)条边,所以我们并不用在\(DAG\)上\(dp\),直接在建出来的树上\(dp\)就好了。

转移的话,对于一条树边\(u->v\)我们先枚举转移之后的\(u\)的排名,再枚举当前\(v\)的排名,我们发现还需要枚举\(v\)的子树在\(u\)排名之前的点的个数\(x\)。

当\(u\)需要在\(v​\)之后时:

\[dp[u][j]=\sum_{k=1}^{k\leq size[v]}\sum_{x=k}^{x\leq size[v]}dp[u][j-x]*\binom{j-1}{x}*\binom{size[u]-(j-x)+size[v]-x}{size[v]-x}
\]

发现转移是一个后缀和的形式,可以用后缀和优化)。

当\(u\)需要在\(v\)之前时。

\[dp[u][j]=\sum_{k=1}^{k\leq size[v]}\sum_{x=1}^{x<k}dp[u][j-x]*\binom{j-1}{x}*\binom{size[u]-(j-x)+size[v]-x}{size[v]-x}
\]

转移是一个前缀和的形式,也可以用前缀和优化。

经过优化后,这个\(dp\)的复杂度可以优化到树形背包的复杂度,也就是\(O(n^2)\)。

代码

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#define N 1009
using namespace std;
typedef long long ll;
const int maxn=1000;
const int mod=1000000007;
char s[1];
ll ans,dp[N][N],now[N],c[N][N],g[N];
int tot,head[N],size[N],n;
inline ll rd(){
ll x=0;char c=getchar();bool f=0;
while(!isdigit(c)){if(c=='-')f=1;c=getchar();}
while(isdigit(c)){x=(x<<1)+(x<<3)+(c^48);c=getchar();}
return f?-x:x;
}
inline void MOD(ll &x){x=x>=mod?x-mod:x;}
struct edge{int n,to,l;}e[N<<1];
inline void add(int u,int v,int l){e[++tot].n=head[u];e[tot].to=v;head[u]=tot;e[tot].l=l;}
void dfs(int u,int fa){
size[u]=1;
dp[u][1]=1;
for(int i=head[u];i;i=e[i].n){
int v=e[i].to;if(v==fa)continue;
dfs(v,u);
if(e[i].l){
for(int j=1;j<=size[u]+size[v];++j){
int ma=min(size[v],j-1);
now[ma+1]=0;
for(int x=ma;x>=1;--x)
MOD(now[x]=now[x+1]+dp[u][j-x]*c[j-1][x]%mod*c[size[u]-(j-x)+size[v]-x][size[v]-x]%mod);
for(int k=1;k<=size[v];++k)MOD(g[j]+=dp[v][k]*now[k]%mod),now[k]=0;
}
}
else{
for(int j=1;j<=size[u]+size[v];++j){
int ma=min(size[v],j-1);
for(int x=0;x<=ma;++x)
MOD(now[x]=now[x-1]+dp[u][j-x]*c[j-1][x]%mod*c[size[u]-(j-x)+size[v]-x][size[v]-x]%mod);
for(int k=1;k<=size[v];++k)MOD(g[j]+=now[min(k-1,ma)]*dp[v][k]%mod);
for(int x=0;x<=ma;++x)now[x]=0;
}
}
size[u]+=size[v];
for(int j=1;j<=size[u];++j)dp[u][j]=g[j],g[j]=0;
}
}
int main(){ // 1 -> dayu 0 -> xiaoyu
int T=rd();
c[0][0]=1;
for(int i=1;i<=maxn;++i){
c[i][0]=1;
for(int j=1;j<=i;++j)MOD(c[i][j]=c[i-1][j]+c[i-1][j-1]);
}
while(T--){
n=rd();int u,v;
memset(dp,0,sizeof(dp));
memset(head,0,sizeof(head));tot=0;
for(int i=1;i<n;++i){
u=rd()+1;scanf("%s",s);v=rd()+1;
add(u,v,s[0]=='>');add(v,u,s[0]=='<');
}
ans=0;dfs(1,0);
for(int i=1;i<=n;++i)MOD(ans+=dp[1][i]);
printf("%lld\n",ans);
}
return 0;
}

HEOI2013SAO的更多相关文章

  1. BZOJ3167/BZOJ4824 HEOI2013SAO/CQOI2017老C的键盘(树形dp)

    前者是后者各方面的强化版. 容易想到设f[i][j]表示i子树中第j小的是i的方案数(即只考虑相对关系).比较麻烦的在于转移.考虑逐个合并子树.容易想到枚举根原来的排名和子树根原来的排名,算一发组合数 ...

  2. CodeChef LEMOVIE

    题意:给你n个数字(下标不同数值相同的数字应当被认为是不同的数字),有n!种排列方式.每种排列方式的价值定义为:第一次出现时比前面的所有数字都大的数值个数. 比如1,2,2,3这个排列中,1,2,3这 ...

随机推荐

  1. Vb.net MakeLong MAKELPARAM 合并整数代码

    Function MAKELPARAM(wLow As UShort, wHigh As UShort) As UInteger Return wHigh * &H10000 + wLow E ...

  2. ASP.NET WebApi系列

    ASP.NET Web API 是一种框架,用于轻松构建可以访问多种客户端(包括浏览器和移动设备)的 HTTP 服务. ASP.NET Web API 是一种用于在 .NET Framework 上构 ...

  3. OrmLite-更符合面向对象的数据库操作方式

    1. jar包下载 下载地址:http://ormlite.com/releases/,一般用core和android包即可. 如果使用的是android studio,也可以直接通过module s ...

  4. Flutter项目之app升级方案

    题接上篇的文章的项目,还是那个空货管理app.本篇文章用于讲解基于Flutter的app项目的升级方案. 在我接触Flutter之前,做过一个比较失败的基于DCloud的HTML5+技术的app,做过 ...

  5. 微信小程序中通过腾讯地图进行逆地址解析报错message: "请求来源未被授权, 此次请求来源域名:servicewechat.com"

    在小程序中获取定位具体信息时,不要配置腾讯地图中的WebServiceAPI中的域名白名单什么的,域名配置直接在小程序后台中配置(就是这个货https://apis.map.qq.com), 千万千万 ...

  6. 人脸识别ArcFace C#DEMO 开发应用全过程

    手上有一个项目,需要检验使用本程序的,是否本人!因为在程序使用前,我们都已经做过头像现场采集,所以源头呢是不成问题的,那么人脸检测,人脸比对,怎么办呢?度娘了下,目前流行的几个人脸检测,人脸比对核心, ...

  7. Git - git status - 查看当前仓库状态

    索引: 目录索引 参看代码 GitHub: git.txt 一.示例: git status 二.说明: 1."status" 部分 该命令可以查出当前分支文件变更状态, 可以查出 ...

  8. Vue的安装及使用快速入门

    一.安装vue 1.安装node.js,安装完node.js之后,npm也会自动安装 查询是否安装成功的命令: node -v npm -v 2.全局安装脚手架工具vue-cli,命令如下: npm ...

  9. 基于GPS数据建立隐式马尔可夫模型预测目的地

    <Trip destination prediction based on multi-day GPS data>是一篇在2019年,由吉林交通大学团队发表在elsevier期刊上的一篇论 ...

  10. 理解jQuery的$.extend与$.fn.extend

    https://www.cnblogs.com/xuxiuyu/p/5989743.html 上面这篇博客总结的很棒!!,以下对自己的认识做一个总结 <!DOCTYPE html> < ...