心态崩了 不放传送门了 辣鸡bz

还是正经一点写一下题解= =

就是显然我们可以把权值写成生成函数形式g(0/1序列)来表示权值是否出现

然后f来表示总的方案数

可以列出 分别枚举左右子树和空树的情况

然后解方程得到

显然开根开出来常数项是1 而g不带常数项 那么就必须取-才能保证除法有效

然后为了计算方便我们把柿子写成(平方差上下同乘)

然后就是多项式开根和多项式求逆了

多项式求逆可以戳我的【学习笔记】

然后开根是类似的 也是通过倍增 可以得到递归求解就好了

这个最可怕的是所以是随便套 就非常恐怖了(囧

然后我就发现我的写法写多项式开根非常麻烦 然后就开始胡乱改

常数上天 BZT飞

本来写的心态就很不好 懒得改了= =

所以这份代码BZ是会T掉的 小心食用qwq

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define ll long long
#define inf 20021225
#define wph 998244353
#define G 3
#define mxn 1600010
#define inv2 499122177
#define int ll
using namespace std;
int rev[mxn],inv; int ksm(int bs,int mi)
{
int ans=1;
while(mi)
{
if(mi&1) ans=(ll)ans*bs%wph;
bs=(ll)bs*bs%wph; mi>>=1;
}
return ans;
} int init(int n)
{
int lim=1,l=0;
while(lim<n) lim<<=1,l++;
for(int i=0;i<lim;i++)
rev[i] = (rev[i>>1]>>1)|((i&1)<<(l-1));
inv = ksm(lim,wph-2);
return lim;
} void ntt(int *a,int n,int f)
{
for(int i=0;i<n;i++)
if(rev[i]>i) swap(a[i],a[rev[i]]);
for(int k=2;k<=n;k<<=1)
{
int Wn=ksm(G,(wph-1)/k),mid=k>>1;
if(f) Wn=ksm(Wn,wph-2);
for(int w=1,i=0;i<n;i+=k,w=1)
{
for(int j=0;j<mid;j++,w=(ll)w*Wn%wph)
{
int x=a[i+j],y=(ll)w*a[i+j+mid]%wph;
a[i+j]=(x+y)%wph;a[i+j+mid]=(x-y+wph)%wph;
}
}
}
if(f) for(int i=0;i<n;i++) a[i]=(ll)a[i]*inv%wph;
}
int f[mxn],g[mxn],h[mxn];
void poly_inv(int *a,int n)
{
if(n==1)
{
g[0] = ksm(a[0],wph-2);
return;
}
int mid = (n+1)>>1;
poly_inv(a,mid);
int lim = init(n<<1);
for(int i=0;i<n;i++) h[i]=a[i];
for(int i=n;i<lim;i++) h[i]=0;
ntt(h,lim,0); ntt(g,lim,0);
for(int i=0;i<lim;i++)
g[i] = (2ll - (ll)h[i]*g[i]%wph + wph)%wph *g[i] %wph;
ntt(g,lim,1);
for(int i=n;i<lim;i++) g[i]=0;
}
int d[mxn],t[mxn];
void poly_sqrt(int a[],int n)
{
//printf("%d\n",n);
if(n==1){d[0] = 1;return;}
int mid = n>>1; poly_sqrt(a,mid);
int lim = init(n);// while(lim<(n<<1)) lim<<=1;
memset(g,0ll,sizeof(ll)*n*2);
poly_inv(d,n);
for(int i=0;i<n;i++) h[i]=a[i];
for(int i=n;i<lim*2;i++) h[i]=0;
lim = init(n<<1);
ntt(h,lim,0); ntt(g,lim,0); ntt(d,lim,0);
for(int i=0;i<lim;i++)
d[i] = ((ll)h[i]*g[i]%wph + d[i])%wph *inv2%wph;
ntt(d,lim,1);
for(int i=n;i<lim;i++) d[i]=0;
}
int a[mxn];
signed main()
{
int n,m,x;
scanf("%lld%lld",&n,&m);
for(int i=1;i<=n;i++)
{
scanf("%lld",&x);
if(x<=m) f[x] = wph - 4;
}
f[0]=1;
int lim=init(m<<1);
poly_sqrt(f,lim);
d[0]++;
//for(int i=0;i<(m<<1);i++) printf("%d ",d[i]);
memset(g,0,sizeof(g));
lim = init(m<<1);
poly_inv(d,lim);// printf("%d ",g[0]*2%wph);
for(int i=1;i<=m;i++) printf("%lld\n",g[i]*2%wph);
/**scanf("%d",&n);
for(int i=0;i<n;i++) scanf("%d",&f[i]);
poly_inv(f,n);
for(int i=0;i<n;i++) printf("%d ",g[i]);*/
return 0;
}
/**
*/

BZOJ3625 CF438E 小朋友与二叉树的更多相关文章

  1. [BZOJ3625][CF438E]小朋友和二叉树

    题面 Description 我们的小朋友很喜欢计算机科学,而且尤其喜欢二叉树. 考虑一个含有\(n\)个互异正整数的序列\(c_1,c_2,\ldots,c_n\).如果一棵带点权的有根二叉树满足其 ...

  2. [BZOJ3625][CF438E]小朋友和二叉树 (多项式开根,求逆)

    题面 题解 设多项式的第a项为权值和为a的二叉树个数,多项式的第a项表示是否为真,即 则,所以F是三个多项式的卷积,其中包括自己: ,1是F的常数项,即. 我们发现这是一个一元二次方程,可以求出,因为 ...

  3. [CF438E] 小朋友和二叉树

    Description 给定一个整数集合 \(c\),对于每个 \(i\in[1,m]\),求有多少种不同的带点权的二叉树使得这棵树点权和为 \(i\) 并且顶点的点权全部在集合 \(c\) 中.\( ...

  4. 【bzoj3625】【xsy1729】小朋友和二叉树

    [bzoj3625]小朋友与二叉树 题意 我们的小朋友很喜欢计算机科学,而且尤其喜欢二叉树. 考虑一个含有n个互异正整数的序列c[1],c[2],...,c[n].如果一棵带点权的有根二叉树满足其所有 ...

  5. 【BZOJ3625/CF438E】小朋友和二叉树(多项式求逆,多项式开方)

    [BZOJ3625/CF438E]小朋友和二叉树(多项式求逆,多项式开方) 题面 BZOJ CodeForces 大致题意: 对于每个数出现的次数对应的多项式\(A(x)\) 求\[f(x)=\fra ...

  6. 【CF438E】小朋友和二叉树 解题报告

    [CF438E]小朋友和二叉树 Description ​ 我们的小朋友很喜欢计算机科学,而且尤其喜欢二叉树. ​ 考虑一个含有\(n\)个互异正整数的序列\(c_1,c_2,\dots,c_n\). ...

  7. BZOJ 3625: [Codeforces Round #250]小朋友和二叉树

    3625: [Codeforces Round #250]小朋友和二叉树 Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 304  Solved: 13 ...

  8. 「BZOJ 3645」小朋友与二叉树

    「BZOJ 3645」小朋友与二叉树 解题思路 令 \(G(x)\) 为关于可选大小集合的生成函数,即 \[ G(x)=\sum[i\in c ] x^i \] 令 \(F(x)\) 第 \(n\) ...

  9. [BZOJ 3625] [Codeforces 438E] 小朋友的二叉树 (DP+生成函数+多项式开根+多项式求逆)

    [BZOJ 3625] [Codeforces 438E] 小朋友的二叉树 (DP+生成函数+多项式开根+多项式求逆) 题面 一棵二叉树的所有点的点权都是给定的集合中的一个数. 让你求出1到m中所有权 ...

随机推荐

  1. 用树状数组写的最长上升子序列(友好城市),nlogn。

    #include<iostream> #include<algorithm> #define maxn 100000 #define lb(x) x&-x using ...

  2. 让VirtualBox虚拟机实现开机自动后台运行

    转至:http://www.cnblogs.com/top5/archive/2012/01/19/2326234.html 测试环境:Host OS: Windows 7 x64 Guest OS: ...

  3. CF 1182F Maximum Sine——根号算法

    题目:http://codeforces.com/contest/1182/problem/F 注意有绝对值. 那么就是 k*p 对 q 取模,找最接近 \(\frac{q}{2}\) 的结果. 也就 ...

  4. E:\Postgresql\pgAdmin4_binaryPath

    e Path to the directory containing the EDB Advanced Server utility programs (pg_dump, pg_restore etc ...

  5. day10—jQuery初步实践,关于菜单

    转行学开发,代码100天——2018-03-26 今天是本人写开发记录方面博客的第10天了,不知不觉已经涉及到jQuery框架的学习了. 第一次熬夜写前端代码还是两年前,不过中途放弃了,学的东西也日渐 ...

  6. mybatis有结果返回null

    解决:application.yml 中mybatis此项(解决驼峰及数据库字段有下划线问题) map-underscore-to-camel-case: true 问题: mybatis debug ...

  7. 将多个jpg文件以追加形式合并成一个文件_delphi教程 bmp 合并 http://www.west.cn/www/info/58058-1.htm

    将多个jpg文件以追加形式合并成一个文件_delphi教程 作者:网友供稿 点击:0 西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!云服务器 ...

  8. Nginx 配置 location 以及 return、rewrite 和 try_files 指令

    正则表达式 Nginx 内置的全局变量 location 前缀字符串及优先级 示例 location 匹配原则 if 和 break 指令 if break return.rewrite 和 try_ ...

  9. Drone 中的概念:webhooks、workspace、cloning、pipelines、services、plugins、deployments

    webhooks 跳过提交 包含/跳过分支 branches workspace base 属性 path 属性 cloning pipelines 构建步骤 并行执行 group 条件执行 when ...

  10. WEB服务端安全---文件上传漏洞

    1.简述 文件上传漏洞是指用户上传了一个可执行的脚本文件,并通过此脚本文件获得了执行服务端命令的能力.这种攻击方式是最直接和有效的,而且互联网中我们经常会用到文件上传功能,它本身是没有问题的,正常的业 ...