【JZOJ 5418】【NOIP2017提高A组集训10.24】合影
2017-10-24 16:34
477 查看
Description
经过一天的忙碌,志愿者们结束了他们的工作,准备站在一排合影留念。现在总共有n名志愿者留下来准备合影。不过,进程并不是那么顺利,有些同学提出了一些奇奇怪怪的要求(每个人最多只会提出一个):他必须站在另外一个同学的左边(不一定相邻),仁慈的老师满足了他们的要求。这时,其中一位来自11班的同学小Z陷入了沉思:总共有多少种不同的合法方案数呢?(两种方案不同当且仅存在至少一名同学他在这两个方案当中站的位置不同。)小Z很快就算出来了,于是就把自己的这个问题告诉了好朋友小C。不过,由于小C的数学功底不足,小Z只要求他算出这个答案模质数p的余数就可以了。可就算这样,小C也不会做。为了显示自己的水平很高(实际上很低),他找到了你,并把你得出的答案报给小Z,所以你可一定要算对啊!
Solution
注意到题目的那句话了吗,限制条件是一棵树,不是一个DAG!!!
好了,现在这题变成大水题了,直接树形DP,用C公式即可
复杂度:O(n)
Code
#include <cstdio> #define fo(i,a,b) for(int i=a;i<=b;i++) #define fod(i,a,b) for(int i=a;i>=b;i--) #define efo(i,q) for(int i=A[q];i;i=B[i][0]) #define min(q,w) ((q)>(w)?(w):(q)) #define max(q,w) ((q)<(w)?(w):(q)) using namespace std; typedef long long LL; const int N=200500; int read(int &n) { char ch=' ';int q=0,w=1; for(;(ch!='-')&&((ch<'0')||(ch>'9'));ch=getchar()); if(ch=='-')w=-1,ch=getchar(); for(;ch>='0' && ch<='9';ch=getchar())q=q*10+ch-48;n=q*w;return n; } int m,n,ans,mo; LL jc ,jcn ; int B[2*N][2],A ,B0; int b ,z ; bool BK; struct qqww { int si; LL ans; }a ; LL ksm(LL q,int w) { LL ans=1; for(q%=mo;w;w>>=1,q=q*q%mo)if(w&1)ans=ans*q%mo; return ans; } void link(int q,int w) { b[w]++; B[++B0][0]=A[q];A[q]=B0,B[B0][1]=w; } LL C(int m,int n){return jc[m]*jcn %mo*jcn[m-n]%mo;} int dfs(int q) { if(z[q]){BK=1;return 0;} a[q].ans=1;a[q].si=0; z[q]=1; efo(i,q) { a[q].si+=dfs(B[i][1]); if(BK)return 0; a[q].ans=a[q].ans*C(a[q].si,a[B[i][1]].si)%mo*a[B[i][1]].ans%mo; } return ++a[q].si; } int main() { int q,w,_; read(_);jc[0]=jcn[0]=1; while(_--) { BK=0; read(n),read(m),read(mo); fo(i,1,n+1)A[i]=b[i]=z[i]=0,jc[i]=jc[i-1]*(LL)i%mo; jcn[n+1]=ksm(jc[n+1],mo-2); fod(i,n,1)jcn[i]=jcn[i+1]*(LL)(i+1)%mo; B0=A[0]=z[0]=0; fo(i,1,m)read(w),read(q),link(q,w); fo(i,1,n)if(!b[i])link(0,i); dfs(0); q=0; fo(i,1,n)if(z[i])q++; if(q!=n)BK=1; if(BK)printf("0\n"); else printf("%lld\n",a[0].ans); } return 0; }
相关文章推荐
- JZOJ5418. 【NOIP2017提高A组集训10.24】 树形DP+组合数
- JZOJ5419. 【NOIP2017提高A组集训10.24】线段树
- JZOJ 5419. 【NOIP2017提高A组集训10.24】筹备计划
- JZOJ5419. 【NOIP2017提高A组集训10.24】筹备计划
- 【JZOJ 5417】【NOIP2017提高A组集训10.24】方阵
- JZOJ 5417. 【NOIP2017提高A组集训10.24】方阵
- 【JZOJ 5419】【NOIP2017提高A组集训10.24】筹备计划
- JZOJ5418. 【NOIP2017提高A组集训10.24】合影
- JZOJ5409. 【NOIP2017提高A组集训10.21】Fantasy
- 【JZOJ 5416】【NOIP2017提高A组集训10.22】密码
- JZOJ5426. 【NOIP2017提高A组集训10.25】摘Galo
- [JZOJ5436]【NOIP2017提高A组集训10.30】Group
- JZOJ 5435. 【NOIP2017提高A组集训10.30】Graph
- JZOJ 5414. 【NOIP2017提高A组集训10.22】幸运值
- [JZOJ5413]【NOIP2017提高A组集训10.22】清兰
- [JZOJ5424]【NOIP2017提高A组集训10.25】凤凰院凶真
- JZOJ 5426. 【NOIP2017提高A组集训10.25】摘Galo
- 【JZOJ5434】【NOIP2017提高A组集训10.30】Matrix
- JZOJ 5434. 【NOIP2017提高A组集训10.30】Matrix
- JZOJ5439. 【NOIP2017提高A组集训10.31】Calculate 乱搞