FFT
 #include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<algorithm>
#define maxn 1000005
using namespace std;
inline int read() {
int x=,f=;char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-;
for(;isdigit(ch);ch=getchar()) x=x*+ch-'';
return x*f;
}
double pi=acos(-1.0);
struct complex {
double x,y;
complex (double xx=,double yy=) {x=xx;y=yy;}
complex operator +(const complex b) const {return complex(x+b.x,y+b.y);}
complex operator -(const complex b) const {return complex(x-b.x,y-b.y);}
complex operator *(const complex b) const {return complex(x*b.x-y*b.y,x*b.y+y*b.x);}
}a[maxn],b[maxn];
int n,m;
int limit=,l,pos[maxn];
void FFT(complex *A,int tp) {
for(int i=;i<limit;i++) if(i<pos[i]) swap(A[i],A[pos[i]]);
for(int mid=;mid<limit;mid<<=) {
complex wn(cos(pi/mid),tp*sin(pi/mid));
for(int R=mid<<,j=;j<limit;j+=R) {
complex w(,);
for(int k=;k<mid;k++,w=w*wn) {
complex x=A[j+k],y=w*A[j+mid+k];
A[j+k]=x+y;
A[j+mid+k]=x-y;
}
}
}
return ;
}
int main() {
n=read(),m=read();
for(int i=;i<=n;i++) a[i].x=read();
for(int i=;i<=m;i++) b[i].x=read();
while(limit<=n+m) limit<<=,l++;
for(int i=;i<limit;i++) pos[i]=(pos[i>>]>>)|((i&)<<(l-));
FFT(a,);
FFT(b,);
for(int i=;i<limit;i++) a[i]=a[i]*b[i];
FFT(a,-);
for(int i=;i<=n+m;i++) printf("%d ",(int)(a[i].x/limit+0.5));
}

FFT

 生成函数

小A有ai个价值为Ai的物品,小B有bi个价值为Ai的物品,求用两个组成价值为ci的方案数

生成函数可以解决上面的这个问题,构造两个多项式,第X的Ai次方项的系数表示价值为i的物品有多少个,对两个人分别构造,乘在一起的多项式就代表所有的方案数。

原根

定义P的原根为满足的整数g。

NTT

 #include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<algorithm>
#define maxn 4000001
#define mod 998244353
#define ll long long
using namespace std;
inline int read() {
int x=,f=;char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-;
for(;isdigit(ch);ch=getchar()) x=x*+ch-'';
return x*f;
}
ll a[maxn],b[maxn],pos[maxn];
ll n,m,limit=,l,g=;
ll power(ll x,ll y) {
ll ans=;
while(y) {
if(y&) ans*=x,ans%=mod;
x*=x,x%=mod;y>>=;
}
return ans;
}
void NTT(ll *A,int tp) {
for(int i=;i<limit;i++) if(i<pos[i]) swap(A[i],A[pos[i]]);
for(int mid=;mid<limit;mid<<=) {
ll wn=power(g,(mod-)/(mid<<));
if(tp==-) wn=power(wn,mod-);
for(int j=;j<limit;j+=(mid<<)) {
ll w=;
for(int k=;k<mid;k++,w*=wn,w%=mod) {
ll x=A[j+k],y=w*A[j+mid+k];
A[j+k]=x+y;A[j+k]=(A[j+k]%mod+mod)%mod;
A[j+mid+k]=x-y;A[j+mid+k]=(A[j+mid+k]%mod+mod)%mod;
}
}
}
if(tp==-) {
ll ny=power(limit,mod-);
for(int i=;i<limit;i++) A[i]*=ny,A[i]=(A[i]%mod+mod)%mod;
}
}
int main() {
n=read(),m=read();
for(int i=;i<=n;i++) a[i]=read();
for(int i=;i<=m;i++) b[i]=read();
while(limit<=n+m) limit<<=,l++;
for(int i=;i<limit;i++) pos[i]=(pos[i>>]>>)|((i&)<<(l-));
NTT(a,);
NTT(b,);
for(int i=;i<limit;i++) a[i]=a[i]*b[i],a[i]=(a[i]%mod+mod)%mod;
NTT(a,-);
for(int i=;i<=n+m;i++) printf("%lld ",a[i]);
}

NTT

多项式求逆

 #include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<algorithm>
#define ll long long
#define mod 998244353
#define maxn 1000000
using namespace std;
inline int read() {
int x=,f=;char ch=getchar();
for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-;
for(;isdigit(ch);ch=getchar()) x=x*+ch-'';
return x*f;
}
ll g=,limit=,l,n;
ll a[maxn],b[maxn],pos[maxn],c[maxn];
ll power(ll x,ll y) {
ll ans=;
while(y) {
if(y&) ans*=x,ans%=mod;
x*=x,x%=mod;y>>=;
}
return ans;
}
void NTT(ll *A,int tp) {
for(int i=;i<limit;i++) if(i<pos[i]) swap(A[i],A[pos[i]]);
for(int mid=;mid<limit;mid<<=) {
ll wn=power(g,(mod-)/(mid<<));
if(tp==-) wn=power(wn,mod-);
for(int j=;j<limit;j+=(mid<<)) {
ll w=;
for(int k=;k<mid;k++,w*=wn,w%=mod) {
ll x=A[j+k],y=w*A[j+mid+k]%mod;
A[j+k]=x+y;A[j+k]=(A[j+k]%mod+mod)%mod;
A[j+mid+k]=x-y;A[j+mid+k]=(A[j+mid+k]%mod+mod)%mod;
}
}
}
if(tp==-) {
ll ny=power(limit,mod-);
for(int i=;i<limit;i++) A[i]*=ny,A[i]=(A[i]%mod+mod)%mod;
}
}
int d[maxn];
void inv(int step,ll *A,ll *B) {
if(step==) {B[]=power(A[],mod-);return;}
inv((step+)>>,A,B);
l=,limit=;
while(limit<=(step<<)) limit<<=,l++;
for(int i=;i<limit;i++) pos[i]=(pos[i>>]>>)|((i&)<<(l-));
for(int i=;i<step;i++) c[i]=A[i];
for(int i=step;i<limit;i++) c[i]=;
NTT(c,);NTT(B,);
for(int i=;i<limit;i++) B[i]=((2ll-c[i]*B[i]%mod)+mod)%mod*B[i]%mod;
NTT(B,-);
for(int i=step;i<limit;i++) B[i]=;
}
int main() {
n=read();
for(int i=;i<n;i++) a[i]=read();
inv(n,a,b);
for(int i=;i<n;i++) printf("%lld ",b[i]);
}

多项式求逆

多项式开根

 void getsqr(ll *A,ll *B,ll len) {
if(len==) {B[]=;return;}
getsqr(A,B,(len+)>>);
memset(invb,,sizeof(invb));
getinv(B,invb,len);
l=,limit=;
while(limit<=(len<<)) limit<<=,l++;
for(int i=;i<limit;i++) pos[i]=(pos[i>>]>>)|((i&)<<(l-));
for(int i=;i<len;i++) c[i]=A[i];
for(int i=len;i<limit;i++) c[i]=;
NTT(invb,);NTT(c,);NTT(B,);
for(int i=;i<limit;i++) {B[i]=((c[i]*invb[i]%mod)*inv2%mod+B[i]*inv2)%mod;}
NTT(B,-);
for(int i=len;i<limit;i++) B[i]=;
}

FFT模板 生成函数 原根 多项式求逆 多项式开根的更多相关文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  9. 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\) \( ...

随机推荐

  1. windows下vue项目启动步骤

    原创:https://blog.csdn.net/qq_27680317/article/details/71123051?locationNum=10&fps=1 不是ngnix服务器是,忽 ...

  2. Mobile phones POJ - 1195 二维树状数组求和

    Suppose that the fourth generation mobile phone base stations in the Tampere area operate as follows ...

  3. bzoj [POI2005]Kos-Dicing 二分+网络流

    [POI2005]Kos-Dicing Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1835  Solved: 661[Submit][Status][ ...

  4. 字符串模式匹配算法--BF和KMP详解

    1,问题描述 字符串模式匹配:串的模式匹配 ,是求第一个字符串(模式串:str2)在第二个字符串(主串:str1)中的起始位置. 注意区分: 子串:要求连续   (如:abc 是abcdef的子串) ...

  5. Android实现自动定位城市并获取天气信息

    定位实现代码: <span style="font-size:14px;">import java.io.IOException; import java.util.L ...

  6. 洛谷 P1044 栈

    题目背景 栈是计算机中经典的数据结构,简单的说,栈就是限制在一端进行插入删除操作的线性表. 栈有两种最重要的操作,即pop(从栈顶弹出一个元素)和push(将一个元素进栈). 栈的重要性不言自明,任何 ...

  7. MyBatis框架的使用及源码分析(九) Executor

    从<MyBatis框架的使用及源码分析(八) MapperMethod>文中我们知道执行Mapper的每一个接口方法,最后调用的是MapperMethod.execute方法.而当执行Ma ...

  8. Maven-Standard Directory Layout

    顶层工程描述文件: pom.xml. 此外, 还有一些供用户阅读以快速理解工程的文本性文档, 如: readme.txt, license.txt,等. 该结构下只有2个子目录, src和target ...

  9. java中各种循环

    简单介绍一下java中的一些循环 package test; import org.apache.log4j.Logger; import org.junit.Test; public class F ...

  10. 用vue快速开发app的脚手架工具

    前言 多页面应用于结构较于简单的页面,因为简答的页面使用router又过于麻烦.本脚手架出于这样的场景被开发出来. 使用脚手架搭配Hbuilder也同样可以快速使用vue开发安卓和IOS APP. 本 ...