http://172.20.6.3/Problem_Show.asp?id=2042

题意:求一个次数界为n的多项式在模P并模x^m的意义下的逆元。P=7*17*2^23+1。

多项式逆元的含义以及求逆元的方法:http://blog.miskcoo.com/2015/05/polynomial-inverse

公式推导一下。主要还是NTT的使用,我NTT写错了调了半天,太zz了。

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<complex>
using namespace std;
#define LL long long
const LL P=(LL)**(<<)+;
const int maxn=;
LL a[maxn]={},b[maxn]={},e[maxn]={},zz[][maxn]={};
int bel[maxn]={};
int bt,s,tot=;
LL mpow(LL x,LL k){
if(k<){x=mpow(x,P-);k=-k;}
LL z=;
while(k){
if(k&)z=(z*x)%P;
x=(x*x)%P;
k/=;
}return z;
}
inline void getit(){ for(int i=;i<s;i++)bel[i]=((bel[i>>]>>)|((i&)<<(bt-))); }
inline void ntt(LL *c,int n,int dft){
for(int i=;i<n;i++)if(bel[i]>i)swap(c[bel[i]],c[i]);
for(int step=;step<n;step<<=){
LL w=mpow(,((P-)/(step*))*dft);
for(int j=;j<n;j+=(step<<)){
LL z=;
for(int i=j;i<j+step;++i){
LL x=c[i],y=(c[i+step]*z)%P;
c[i]=(x+y)%P;
c[i+step]=((x-y)%P+P)%P;
z=(z*w)%P;
}
}
}
if(dft==-){
LL mon=mpow(n,P-);
for(int i=;i<n;i++)c[i]=(c[i]*mon)%P;
}
}
inline void dontt(LL *c,LL *d,int x,int y){
bt=;s=;int z=x+y-;
for(;s<z;++bt)s<<=;
getit();
ntt(c,s,);ntt(d,s,);
for(int i=;i<s;i++)c[i]=(c[i]*d[i])%P;
ntt(c,s,-);ntt(d,s,);
}
inline void doit(int n,int m){
if(m==){++tot; zz[tot][]=mpow(a[],P-); return ;}
doit(n,(m+)/);int siz=(m+)/; ++tot;
for(int i=;i<s;i++)e[i]=b[i]=bel[i]=;
for(int i=;i<siz;i++){zz[tot][i]=(zz[tot-][i]*)%P;b[i]=zz[tot-][i];}
for(int i=min(n,m)-;i>=;--i)e[i]=a[i];
dontt(zz[tot-],b,siz,siz); siz=siz+siz-;
dontt(zz[tot-],e,siz,min(n,m));
for(int i=;i<m;i++)zz[tot][i]=((zz[tot][i]-zz[tot-][i])%P+P)%P;
}
int main(){
//freopen("a.in","r",stdin);
int n,m;scanf("%d%d",&n,&m);
for(int i=;i<n;i++){scanf("%lld",&a[i]);a[i]=((a[i]%P)+P)%P;}
doit(n,m);
for(int i=;i<m;i++)printf("%lld ",zz[tot][i]);
printf("\n");
return ;
}

JZYZOJ 2042 多项式逆元 NTT 多项式的更多相关文章

  1. luoguP4512 【模板】多项式除法 NTT+多项式求逆+多项式除法

    Code: #include<bits/stdc++.h> #define maxn 300000 #define ll long long #define MOD 998244353 # ...

  2. 【BZOJ3625】【CF438E】小朋友和二叉树 NTT 生成函数 多项式开根 多项式求逆

    题目大意 考虑一个含有\(n\)个互异正整数的序列\(c_1,c_2,\ldots ,c_n\).如果一棵带点权的有根二叉树满足其所有顶点的权值都在集合\(\{c_1,c_2,\ldots ,c_n\ ...

  3. [拉格朗日反演][FFT][NTT][多项式大全]详解

    1.多项式的两种表示法 1.系数表示法 我们最常用的多项式表示法就是系数表示法,一个次数界为\(n\)的多项式\(S(x)\)可以用一个向量\(s=(s_0,s_1,s_2,\cdots,s_n-1) ...

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

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

  5. 【bzoj3456】城市规划 容斥原理+NTT+多项式求逆

    题目描述 求出n个点的简单(无重边无自环)无向连通图数目mod 1004535809(479 * 2 ^ 21 + 1). 输入 仅一行一个整数n(<=130000) 输出 仅一行一个整数, 为 ...

  6. 洛谷5月月赛T30212 玩游戏 【分治NTT + 多项式求ln】

    题目链接 洛谷T30212 题解 式子很容易推出来,二项式定理展开后对于\(k\)的答案即可化简为如下: \[k!(\sum\limits_{i = 0}^{k} \frac{\sum\limits_ ...

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

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

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

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

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

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

随机推荐

  1. spectrogram函数做短时傅里叶分析

    整理自:http://blog.sina.com.cn/s/blog_6163bdeb0102dwfw.html 今天偶人发现原来matlab自带了短时傅里叶变换的分析函数,老版本的matlab是sp ...

  2. nova-api源码分析(APP的创建)

    目录结构如下: 上面介绍了nova-api发布所用到的一些lib库,有了上面的基础知识,再来分析nova-api的发布流程,就比较轻松了.nova-api可以提供多种api服务:ec2, osapi_ ...

  3. 纯CSS实现表单验证

    ladies and 乡亲们,表单验证你在做吗?客户端or服务器端,javascript or jquery,动手写 or 使用插件,今天我们来探索下使用纯css实现表单验证,借以学习css sele ...

  4. dedecms织梦自增索引标签

    在列表中我们经常会需要动态的索引值,那么就可以用到如下标签 [field:global.autoindex/] 默认是从1开始,如果我们想从0或者从其他数开始如下: [field:autoindex ...

  5. JS 简易控制台插件 [供 博客, 论坛 运行js用]

    今天厚着脸皮来推荐下鄙人写的一个小插件吧.看过我博客的应该都熟悉这个插件了,其实就是这货. 这东西是我去年写的,当时水平也不怎么样,不过好歹还是实现了简单功能.我先简单介绍下这东西什么用吧. 因为在 ...

  6. Spring Mvc + Maven + BlazeDS 与 Flex 通讯 (七)

    BlazeDS 说明 BlazeDS是由Adobe开源的基于amf协议的,用于解决flex与java通讯的组件; 基于传统的文本协议的XML传输方式,在抽象层方面会有很大的压力,特别在需要序列化与反序 ...

  7. PWN入门

    pwn ”Pwn”是一个黑客语法的俚语词 ,是指攻破设备或者系统 .发音类似“砰”,对黑客而言,这就是成功实施黑客攻击的声音——砰的一声,被“黑”的电脑或手机就被你操纵.以上是从百度百科上面抄的简介, ...

  8. 【Pyhon】获取文件MIME类型,根据文件类型自定义文件后缀

    场景 下载样本,都是MD5命名的无后缀文件,需要自己手动查询然后修改文件后缀. 根据文件类型自定义后缀可以很方便地根据后缀判断用什么工具分析. 使用说明 libmagic 地址:https://pyp ...

  9. innobackupex做MySQL增量备份及恢复【转】

    创建备份用户 mysql> grant process,reload,lock tables,replication client on *.* to 'backup'@'localhost' ...

  10. springcloud Zuul中异常处理细节

    Spring Cloud Zuul对异常的处理整体来说还是比较方便的,流程也比较清晰,只是由于Spring Cloud发展较快,各个版本之间有差异,导致有的小伙伴在寻找这方面的资料的时候经常云里雾里, ...