[nowcoder5668J]Operating on the Tree
1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 2005
4 #define mod 998244353
5 struct ji{
6 int nex,to;
7 }edge[N];
8 int E,t,n,x,fac[N],inv[N],head[N],sz[N],g[N][N][3],f[N][N][3];
9 int c(int n,int m){
10 return 1LL*fac[n]*inv[m]%mod*inv[n-m]%mod;
11 }
12 void add(int x,int y){
13 edge[E].nex=head[x];
14 edge[E].to=y;
15 head[x]=E++;
16 }
17 void dfs(int k){
18 sz[k]=g[k][0][0]=g[k][0][2]=1;
19 for(int i=head[k];i!=-1;i=edge[i].nex){
20 int u=edge[i].to;
21 dfs(u);
22 for(int j=1;j<sz[u];j++)
23 for(int p=0;p<3;p++){
24 g[u][j][p]=(g[u][j][p]+g[u][j-1][p])%mod;
25 f[u][j][p]=(f[u][j][p]+f[u][j-1][p])%mod;
26 }
27 for(int j=0;j<sz[k];j++)
28 for(int jj=0;jj<=sz[u];jj++){
29 int C=1LL*c(j+jj,j)*c(sz[k]-j-1+sz[u]-jj,sz[u]-jj)%mod;
30 for(int p1=0;p1<3;p1++)
31 for(int p2=0;p2<3;p2++){
32 int s1=0,s2=0;
33 if (jj){
34 s1=1LL*g[u][jj-1][p2]*g[k][j][p1]%mod*C%mod;
35 s2=(1LL*g[u][jj-1][p2]*f[k][j][p1]+1LL*f[u][jj-1][p2]*g[k][j][p1])%mod*C%mod;
36 }
37 if ((p1==0)&&(p2==1)){
38 g[0][j+jj][0]=(g[0][j+jj][0]+s1)%mod;
39 f[0][j+jj][0]=(f[0][j+jj][0]+s2)%mod;
40 }
41 if ((p1==1)&&(p2<2)||(p1==2)&&(p2==0)){
42 g[0][j+jj][1]=(g[0][j+jj][1]+s1)%mod;
43 f[0][j+jj][1]=(f[0][j+jj][1]+s2)%mod;
44 }
45 if ((p1==2)&&(p2==1)){
46 g[0][j+jj][2]=(g[0][j+jj][2]+s1)%mod;
47 f[0][j+jj][2]=(f[0][j+jj][2]+s2)%mod;
48 }
49 if (!jj)s1=g[u][sz[u]-1][p2];
50 else s1=(g[u][sz[u]-1][p2]-g[u][jj-1][p2]+mod)%mod;
51 if (!jj)s2=f[u][sz[u]-1][p2];
52 else s2=(f[u][sz[u]-1][p2]-f[u][jj-1][p2]+mod)%mod;
53 s2=(1LL*s1*f[k][j][p1]+1LL*s2*g[k][j][p1])%mod*C%mod;
54 s1=1LL*s1*g[k][j][p1]%mod*C%mod;
55 if ((p1==0)&&(p2)){
56 g[0][j+jj][0]=(g[0][j+jj][0]+s1)%mod;
57 f[0][j+jj][0]=(f[0][j+jj][0]+s2)%mod;
58 }
59 if ((p1==1)&&(p2<2)){
60 g[0][j+jj][1]=(g[0][j+jj][1]+s1)%mod;
61 f[0][j+jj][1]=(f[0][j+jj][1]+s2)%mod;
62 }
63 if ((p1==2)&&(p2<2)){
64 g[0][j+jj][2]=(g[0][j+jj][2]+s1)%mod;
65 f[0][j+jj][2]=(f[0][j+jj][2]+s2)%mod;
66 }
67 }
68 }
69 sz[k]+=sz[u];
70 for(int j=0;j<sz[k];j++)
71 for(int p=0;p<3;p++){
72 g[k][j][p]=g[0][j][p];
73 f[k][j][p]=f[0][j][p];
74 g[0][j][p]=f[0][j][p]=0;
75 }
76 }
77 for(int i=0;i<sz[k];i++)f[k][i][0]=(f[k][i][0]+g[k][i][0])%mod;
78 }
79 int main(){
80 fac[0]=inv[0]=inv[1]=1;
81 for(int i=1;i<N-4;i++)fac[i]=1LL*fac[i-1]*i%mod;
82 for(int i=2;i<N-4;i++)inv[i]=1LL*(mod-mod/i)*inv[mod%i]%mod;
83 for(int i=2;i<N-4;i++)inv[i]=1LL*inv[i-1]*inv[i]%mod;
84 scanf("%d",&t);
85 while (t--){
86 scanf("%d",&n);
87 E=0;
88 memset(head,-1,4*(n+1));
89 for(int i=1;i<=n;i++){
90 memset(g[i],0,sizeof(g[i]));
91 memset(f[i],0,sizeof(f[i]));
92 }
93 for(int i=2;i<=n;i++){
94 scanf("%d",&x);
95 add(x+1,i);
96 }
97 dfs(1);
98 int ans=0;
99 for(int i=0;i<n;i++)ans=(ans+0LL+f[1][i][0]+f[1][i][1])%mod;
100 printf("%d\n",ans);
101 }
102 }
[nowcoder5668J]Operating on the Tree的更多相关文章
- Linux and the Device Tree
来之\kernel\Documentation\devicetree\usage-model.txt Linux and the Device Tree ----------------------- ...
- POJ 2420:A Star not a Tree?
原文链接:https://www.dreamwings.cn/poj2420/2838.html A Star not a Tree? Time Limit: 1000MS Memory Limi ...
- Device Tree Usage( DTS文件语法)
http://elinux.org/Device_Tree_Usage Device Tree Usage Top Device Tree page This page walks throu ...
- POJ 2420 A Star not a Tree? 爬山算法
B - A Star not a Tree? Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/co ...
- [POJ 2420] A Star not a Tree?
A Star not a Tree? Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4058 Accepted: 200 ...
- POJ 2420 A Star not a Tree? (计算几何-费马点)
A Star not a Tree? Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3435 Accepted: 172 ...
- Device Tree Usage(理解DTS文件语法)
Basic Data Format The device tree is a simple tree structure of nodes and properties. Properties are ...
- How to Make a Computer Operating System
How to Make a Computer Operating System 如何制作一个操作系统(翻译版) 原文地址:Github:How to Make a Computer Operating ...
- Spanning Tree Protocol (STP) in NetScaler Appliance
Spanning Tree Protocol (STP) in NetScaler Appliance 来源 https://support.citrix.com/article/CTX112341 ...
随机推荐
- CSharpEntityFramework与CodeFirst实践
CSharpEntityFramework与CodeFirst实践 前言 当我们进行开发的时候,常常会用到数据库来对数据进行持久化的操作,有的时候,我们并不想要在进行代码开发的过程中,还去关注数据库的 ...
- VS2013的主函数问题
报错如下: 打开属性里面,修改字符集即可
- PAT (Basic Level) Practice (中文)1017 A除以B (20分)
1017 A除以B (20分) 本题要求计算 A/B,其中 A 是不超过 1000 位的正整数,B 是 1 位正整数.你需要输出商数 Q 和余数 R,使得 A=B×Q+R 成立. 输入格式: 输入在一 ...
- 苹果的最新MacbookPro,炸到你了么?
一 苹果秋季发布会如期而至.我不是一个标准的果粉.但是我今年用上了macbook pro m1,最期待的就是新款的搭载了M1X的Macbook. 苹果官方也放出了要炸翻全场的宣传语... 这次发布会围 ...
- 苹果应用内购 ios 开发者根据用户提供的邮件中的订单号查看该订单是否支付成功
苹果应用内购 ios 开发者根据用户提供的邮件中的订单号查看该订单是否支付成功 这是苹果wwdc2021 推出的新功能 参考官网链接 App Store Server API | Apple Deve ...
- Vim 不区分大小写
Vim 不区分大小写 忽略:set ignorecase 恢复:set noignorecase
- Codeforces1514B
问题描述 给你两个数n,k,问可以构造多少n个最大位数为k数按位与为0并且这n个数加起来最大的合法序列,答案对1e9 + 7取模. 思路分析 首先我们考虑这n个数按位与以后为0这个条件:我们可以知道, ...
- JVM:内存溢出OOM
JVM:内存溢出OOM 本笔记是根据bilibili上 尚硅谷 的课程 Java大厂面试题第二季 而做的笔记 经典错误 JVM 中常见的两个 OOM 错误 StackoverflowError:栈溢出 ...
- 【做题记录】CF1451E2 Bitwise Queries (Hard Version)
CF1451E2 Bitwise Queries (Hard Version) 题意: 有 \(n\) 个数( \(n\le 2^{16}\) ,且为 \(2\) 的整数次幂,且每一个数都属于区间 \ ...
- 用Python去除PDF水印
今天介绍下用 Python 去除 PDF (图片)的水印.思路很简单,代码也很简洁. 首先来考虑 Python 如何去除图片的水印,然后再将思路复用到 PDF 上面. 这张图片是前几天整理<数据 ...