bzoj 3625小朋友和二叉树 多项式求逆+多项式开根 好题
题目大意
给定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小朋友和二叉树 多项式求逆+多项式开根 好题的更多相关文章
- FFT模板 生成函数 原根 多项式求逆 多项式开根
FFT #include<iostream> #include<cstring> #include<cstdlib> #include<cstdio> ...
- 2019.01.01 bzoj3625:小朋友和二叉树(生成函数+多项式求逆+多项式开方)
传送门 codeforces传送门codeforces传送门codeforces传送门 生成函数好题. 卡场差评至今未过 题意简述:nnn个点的二叉树,每个点的权值KaTeX parse error: ...
- 【BZOJ3625】【codeforces438E】小朋友和二叉树 生成函数+多项式求逆+多项式开根
首先,我们构造一个函数$G(x)$,若存在$k∈C$,则$[x^k]G(x)=1$. 不妨设$F(x)$为最终答案的生成函数,则$[x^n]F(x)$即为权值为$n$的神犇二叉树个数. 不难推导出,$ ...
- [Codeforces438E][bzoj3625] 小朋友和二叉树 [多项式求逆+多项式开根]
题面 传送门 思路 首先,我们把这个输入的点的生成函数搞出来: $C=\sum_{i=0}^{lim}s_ix^i$ 其中$lim$为集合里面出现过的最大的数,$s_i$表示大小为$i$的数是否出现过 ...
- bzoj 3456 城市规划——分治FFT / 多项式求逆 / 多项式求ln
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3456 分治FFT: 设 dp[ i ] 表示 i 个点时连通的方案数. 考虑算补集:连通的方 ...
- 【learning】多项式相关(求逆、开根、除法、取模)
(首先要%miskcoo,这位dalao写的博客(这里)实在是太强啦qwq大部分多项式相关的知识都是从这位dalao博客里面学的,下面这篇东西是自己对其博客学习后的一些总结和想法,大部分是按照其博客里 ...
- NTT+多项式求逆+多项式开方(BZOJ3625)
定义多项式$h(x)$的每一项系数$h_i$,为i在c[1]~c[n]中的出现次数. 定义多项式$f(x)$的每一项系数$f_i$,为权值为i的方案数. 通过简单的分析我们可以发现:$f(x)=\fr ...
- 【BZOJ3456】轩辕朗的城市规划 无向连通图计数 CDQ分治 FFT 多项式求逆 多项式ln
题解 分治FFT 设\(f_i\)为\(i\)个点组成的无向图个数,\(g_i\)为\(i\)个点组成的无向连通图个数 经过简单的推导(枚举\(1\)所在的连通块大小),有: \[ f_i=2^{\f ...
- P6295-有标号 DAG 计数【多项式求逆,多项式ln】
正题 题目链接:https://www.luogu.com.cn/problem/P6295 题目大意 求所有\(n\)个点的弱联通\(DAG\)数量. \(1\leq n\leq 10^5\) 解题 ...
随机推荐
- linux目录结构及文件管理
Linux的目录结构: / 根分区 linux文件系统的起点 /bin 普通用户的命令,普通用户能使用 /sbin 管理员使用的命令,只有管理 ...
- Java中线程的通讯
线程间的相互作用:线程之间需要一些协调通信,来共同完成一件任务. Object类中相关的方法有两个notify方法和三个wait方法:因为wait和notify方法定义在Object类中,因此会被所有 ...
- PAT (Basic Level) Practise (中文)- 1007. 素数对猜想 (20)
http://www.patest.cn/contests/pat-b-practise/1007 让我们定义 dn 为:dn = pn+1 - pn,其中 pi 是第i个素数.显然有 d1=1 且对 ...
- HTML5<footer>元素
HTML5中<footer>元素是用来描述文档中的底部信息,比如:版本,版权,作者,链接声明,联系信息,时间等等. 实例: <footer> <p>这是一个底部的信 ...
- 01_4_Struts路径问题
01_4_Struts路径问题 1. Struts路径问题说明 struts2中的路径问题是根据action的路径而不是jsp路径来确定,所有尽量不要使用相对路径. 虽然可以使用redirect方式解 ...
- iOS深拷贝与浅拷贝
概念 对象拷贝有两种方式:浅复制和深复制.顾名思义,浅复制,并不拷贝对象本身,仅仅是拷贝指向对象的指针:深复制是直接拷贝整个对象内存到另一块内存中. 如图详解:
- [].indexOf.call()学习
今天看到闭包一道题,就是一个li列表,点击列表控制台输出对应的索引.这里考察了var的作用域问题和闭包对外部变量的引用问题,有几种解决方法. html: <ul> <li>te ...
- PHP RBAC权限控制,基于CI框架(版本3.1.9)
2018年11月7日更新:目前功能已做到事件级别权限控制,如:后台用户的添加操作.删除操作和保存操作等具体到事件级的操作方法有权限则展示相应的操作菜单,没权限则隐藏相应菜单或提示无权限到目前算是真正做 ...
- node中的定时任务
node-schedule每次都是通过新建一个scheduleJob对象来执行具体方法. 时间数值按下表表示 * * * * * * ┬ ┬ ┬ ┬ ┬ ┬ │ │ │ │ │ | │ │ │ │ │ ...
- How to Install PhantomJS on Ubuntu 16.04
Introduction PhantomJS is a scripted, headless browser that can be used for automating web page inte ...