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\) 解题 ...
随机推荐
- MFC:AfxSetResourceHandle
AfxGetResourceHandle用于获取当前资源模块句柄. 而AfxSetResourceHandle则用于设置程序目前要使用的资源模块句柄,一般在InitInstance()里调用.
- mtDNA|ctDNA|cpDNA|
5.9细胞器基因组是编码细胞器蛋白质的环状DNA分子 细胞器中除真核细胞线粒体DNA(mtDNA)是线性的外,都是环状分子,比如叶绿体DNA(ctDNA,cpDNA).因为单个细胞器有几套不同拷贝的细 ...
- PAT (Basic Level) Practise (中文)- 1014. 福尔摩斯的约会 (20)
http://www.patest.cn/contests/pat-b-practise/1014 1014. 福尔摩斯的约会 (20) 时间限制 50 ms 内存限制 65536 kB 代码长度限制 ...
- Newtonsoft.Json初探
1.序列化 VehicleModelSearchingModel model = new VehicleModelSearchingModel() { brandId = , modelIds=&qu ...
- 01_10_SERVLET如何连接Mysql数据库
01_10_SERVLET如何连接Mysql数据库 1. 实现类 public void doGet(HttpServletRequest request, HttpServletResponse r ...
- 洛谷 P1516 青蛙的约会
https://www.luogu.org/problemnew/show/P1516#sub 题意还是非常好理解的..... 假如这不是一道环形的跑道而是一条直线,你会怎样做呢? 如果是我就会列一个 ...
- 【贪心】bzoj1592: [Usaco2008 Feb]Making the Grade 路面修整
贪心的经典套路:替换思想:有点抽象 Description FJ打算好好修一下农场中某条凹凸不平的土路.按奶牛们的要求,修好后的路面高度应当单调上升或单调下降,也 就是说,高度上升与高度下降的路段不能 ...
- php 正则表达式中的 .*? 表示什么意思
我们知道我 .* 是任意字符,有的时候比较困惑在加个?什么意思. ?是非贪婪模式.*会匹配后面的一切字符,就是到结束的意思加?后就是不贪婪模式,这时要看?后边的字符是什么了,如.*?"的意思 ...
- release判断系统
#!/bin/bash # Name: Atomic Archive configuration script # Copyright Atomicorp, 2002-2018 # License: ...
- destoon修改手机端分页
1. global.func.php pages函数和listpages函数 函数开头增加 $DT_TOUCH,$newsamplepages变量 global $DT_URL, $DT, $L,$D ...