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\) 解题 ...
随机推荐
- 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 += ...
- 利用Vue.js实现登录/登出以及JWT认证
JSON Web Token 入门教程:http://www.ruanyifeng.com/blog/2018/07/json_web_token-tutorial.html 后端代码地址:https ...
- Bootstrap 提示工具(Tooltip)插件方法的用法
方法 下面是一些提示工具(Tooltip)插件中有用的方法: 方法 描述 实例 Options: .tooltip(options) 向元素集合附加提示工具句柄. $().tooltip(option ...
- Oracle 闪回 找回数据的实现方法
Oracle 闪回 找回数据的实现方法 闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复.这篇文章主要介绍了Oracle 闪回 找回 ...
- GCD和NSThread延时执行对比
1.NSThread: [self performSelector:@selector(performSome:) withObject:self afterDelay:.f]; [[self cla ...
- 二叉搜索树详解(Java实现)
1.二叉搜索树定义 二叉搜索树,是指一棵空树或者具有下列性质的二叉树: 若任意节点的左子树不空,则左子树上所有节点的值均小于它的根节点的值: 若任意节点的右子树不空,则右子树上所有节点的值均大于它的根 ...
- [Codeforces Round #250]小朋友和二叉树
题目描述: bzoj luogu 题解: 生成函数ntt. 显然这种二叉树应该暴力薅掉树根然后分裂成两棵子树. 所以$f(x)= \sum_{i \in c} \sum _{j=0}^{x-c} f( ...
- Python爬虫系列-Urllib库详解
Urllib库详解 Python内置的Http请求库: * urllib.request 请求模块 * urllib.error 异常处理模块 * urllib.parse url解析模块 * url ...
- python入门:CONTINUE 的作用 跳出本次循环后,重新开始循环
#!/usr/bin/env python # -*- coding:utf-8 -*- # CONTINUE 的作用 跳出本次循环后,重新开始循环 import time while True: ' ...
- kafka的初认识
学习地址: http://www.jikexueyuan.com/course/1716_3.html?ss=1 http://www.jikexueyuan.com/course/kafka/ zo ...