题目大意

给定n种权值

给定m

\(F_i表示权值和为i的二叉树个数\)

求\(F_1,F_2...F_m\)

分析

安利博客

\(F_d=F_L*F_R*C_{mid},L+mid+R=d\)

\(F(x)=\frac {1+\sqrt{1-4C(x)}}{2C(x)}=\frac 2{1-\sqrt{1-4C(x)}}\)

无解是因为\(x=0\)时\(F(x)=1\)

但是\(\lim\limits_{x\rightarrow 0}\)时\(1-\sqrt{1-4C(x)}趋于0\)

\(F\)趋于INF

同理可证\(F(x)=\frac {1-\sqrt{1-4C(x)}}{2C(x)}\)是正确的

姿势

求逆和开根函数中

static开一些临时数组

写起来方便

但注意初始化

solution

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cctype>
#include <cmath>
#include <algorithm>
using namespace std;
typedef long long LL;
const int M=262145;
const LL Q=998244353; inline int rd(){
int x=0;bool f=1;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=0;
for(;isdigit(c);c=getchar()) x=x*10+c-48;
return f?x:-x;
} int n,m;
LL g,ig,iv2;
LL a[M],b[M];
int rev[M]; LL pwr(LL x,LL tms){
LL res=1;
for(;tms>0;tms>>=1){
if(tms&1) res=res*x%Q;
x=x*x%Q;
}
return res;
} void NTT(LL *a,int N,int fl){
int i,j,k;
LL W,Wn,u,v; for(i=0;i<N;i++) rev[i]=(rev[i>>1]>>1)|((i&1)?(N>>1):0);
for(i=0;i<N;i++) if(i<rev[i]) swap(a[i],a[rev[i]]); for(i=2;i<=N;i<<=1){
if(fl==1) Wn=pwr(g,(Q-1)/i);
else Wn=pwr(ig,(Q-1)/i);
for(j=0;j<N;j+=i){
for(W=1,k=j;k<j+i/2;k++,W=W*Wn%Q){
u=a[k];
v=W*a[k+i/2]%Q;
a[k]=(u+v)%Q;
a[k+i/2]=((u-v)%Q+Q)%Q;
}
}
}
if(fl==-1){
LL iN=pwr(N,Q-2);
for(i=0;i<N;i++) a[i]=a[i]*iN%Q;
} } void INV(LL*a,LL *b,int len){
static LL g[M],tp[M];
if(len==1) b[0]=pwr(a[0],Q-2);
else{
int i;
INV(a,b,len>>1);
int N=len<<1;
for(i=0;i<(len>>1);i++) g[i]=b[i];
for(;i<N;i++) g[i]=b[i]=0;
for(i=0;i<len;i++) tp[i]=a[i];
for(;i<N;i++) tp[i]=0;
NTT(g,N,1);
NTT(tp,N,1);
for(i=0;i<N;i++) tp[i]=g[i]*g[i]%Q*tp[i]%Q;
NTT(tp,N,-1);
for(i=0;i<len;i++) b[i]=((2*b[i]%Q-tp[i])%Q+Q)%Q;
}
} void SQR(LL*a,LL *b,int len){
static LL g[M],tp[M],inv_g[M];
if(len==1) b[0]=1;
else{
int i;
SQR(a,b,len>>1);
int N=len<<1;
for(i=0;i<(len>>1);i++) g[i]=b[i]%Q;
for(;i<N;i++) g[i]=b[i]=0;
for(i=0;i<N;i++) inv_g[i]=0;
INV(g,inv_g,len); for(i=0;i<len;i++) tp[i]=a[i];
for(;i<N;i++) tp[i]=0;
NTT(inv_g,N,1);
NTT(tp,N,1);
for(i=0;i<N;i++) tp[i]=inv_g[i]%Q*tp[i]%Q;
NTT(tp,N,-1);
for(i=0;i<len;i++) b[i]=(b[i]+tp[i])%Q*iv2%Q;
}
} int main(){ int i,x;
n=rd(),m=rd();
for(i=1;i<=n;i++){
x=rd();
a[x]-=4;
if(a[x]<0) a[x]+=Q;
}
a[0]++;
for(n=2;n<=m;n<<=1);
g=3;
ig=pwr(3,Q-2);
iv2=pwr(2,Q-2); SQR(a,b,n); b[0]++;
INV(b,a,n); for(i=0;i<=m;i++) a[i]=(2LL*a[i])%Q;
for(i=1;i<=m;i++) printf("%d\n",a[i]);
return 0;
}

bzoj 3625小朋友和二叉树 多项式求逆+多项式开根 好题的更多相关文章

  1. FFT模板 生成函数 原根 多项式求逆 多项式开根

    FFT #include<iostream> #include<cstring> #include<cstdlib> #include<cstdio> ...

  2. 2019.01.01 bzoj3625:小朋友和二叉树(生成函数+多项式求逆+多项式开方)

    传送门 codeforces传送门codeforces传送门codeforces传送门 生成函数好题. 卡场差评至今未过 题意简述:nnn个点的二叉树,每个点的权值KaTeX parse error: ...

  3. 【BZOJ3625】【codeforces438E】小朋友和二叉树 生成函数+多项式求逆+多项式开根

    首先,我们构造一个函数$G(x)$,若存在$k∈C$,则$[x^k]G(x)=1$. 不妨设$F(x)$为最终答案的生成函数,则$[x^n]F(x)$即为权值为$n$的神犇二叉树个数. 不难推导出,$ ...

  4. [Codeforces438E][bzoj3625] 小朋友和二叉树 [多项式求逆+多项式开根]

    题面 传送门 思路 首先,我们把这个输入的点的生成函数搞出来: $C=\sum_{i=0}^{lim}s_ix^i$ 其中$lim$为集合里面出现过的最大的数,$s_i$表示大小为$i$的数是否出现过 ...

  5. bzoj 3456 城市规划——分治FFT / 多项式求逆 / 多项式求ln

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3456 分治FFT: 设 dp[ i ] 表示 i 个点时连通的方案数. 考虑算补集:连通的方 ...

  6. 【learning】多项式相关(求逆、开根、除法、取模)

    (首先要%miskcoo,这位dalao写的博客(这里)实在是太强啦qwq大部分多项式相关的知识都是从这位dalao博客里面学的,下面这篇东西是自己对其博客学习后的一些总结和想法,大部分是按照其博客里 ...

  7. NTT+多项式求逆+多项式开方(BZOJ3625)

    定义多项式$h(x)$的每一项系数$h_i$,为i在c[1]~c[n]中的出现次数. 定义多项式$f(x)$的每一项系数$f_i$,为权值为i的方案数. 通过简单的分析我们可以发现:$f(x)=\fr ...

  8. 【BZOJ3456】轩辕朗的城市规划 无向连通图计数 CDQ分治 FFT 多项式求逆 多项式ln

    题解 分治FFT 设\(f_i\)为\(i\)个点组成的无向图个数,\(g_i\)为\(i\)个点组成的无向连通图个数 经过简单的推导(枚举\(1\)所在的连通块大小),有: \[ f_i=2^{\f ...

  9. P6295-有标号 DAG 计数【多项式求逆,多项式ln】

    正题 题目链接:https://www.luogu.com.cn/problem/P6295 题目大意 求所有\(n\)个点的弱联通\(DAG\)数量. \(1\leq n\leq 10^5\) 解题 ...

随机推荐

  1. 11.使用while和for循环分别打印字符串s=’asdfer’中每个元素

    1).for循环 s = 'asdfer' for i in s: print(i) 2).while循环 s = 'asdfer' while 1: print(s[index]) index += ...

  2. 利用Vue.js实现登录/登出以及JWT认证

    JSON Web Token 入门教程:http://www.ruanyifeng.com/blog/2018/07/json_web_token-tutorial.html 后端代码地址:https ...

  3. Bootstrap 提示工具(Tooltip)插件方法的用法

    方法 下面是一些提示工具(Tooltip)插件中有用的方法: 方法 描述 实例 Options: .tooltip(options) 向元素集合附加提示工具句柄. $().tooltip(option ...

  4. Oracle 闪回 找回数据的实现方法

    Oracle 闪回 找回数据的实现方法 闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复.这篇文章主要介绍了Oracle 闪回 找回 ...

  5. GCD和NSThread延时执行对比

    1.NSThread: [self performSelector:@selector(performSome:) withObject:self afterDelay:.f]; [[self cla ...

  6. 二叉搜索树详解(Java实现)

    1.二叉搜索树定义 二叉搜索树,是指一棵空树或者具有下列性质的二叉树: 若任意节点的左子树不空,则左子树上所有节点的值均小于它的根节点的值: 若任意节点的右子树不空,则右子树上所有节点的值均大于它的根 ...

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

    题目描述: bzoj luogu 题解: 生成函数ntt. 显然这种二叉树应该暴力薅掉树根然后分裂成两棵子树. 所以$f(x)= \sum_{i \in c} \sum _{j=0}^{x-c} f( ...

  8. Python爬虫系列-Urllib库详解

    Urllib库详解 Python内置的Http请求库: * urllib.request 请求模块 * urllib.error 异常处理模块 * urllib.parse url解析模块 * url ...

  9. python入门:CONTINUE 的作用 跳出本次循环后,重新开始循环

    #!/usr/bin/env python # -*- coding:utf-8 -*- # CONTINUE 的作用 跳出本次循环后,重新开始循环 import time while True: ' ...

  10. kafka的初认识

    学习地址: http://www.jikexueyuan.com/course/1716_3.html?ss=1 http://www.jikexueyuan.com/course/kafka/ zo ...