51nod 1348 乘积之和

#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
#include <map>
#include <bitset>
#include <set>
const int maxlongint=2147483647;
const long long mo=100003;
const int N=300005;
using namespace std;
long long mod[2]={998244353,1004535809},M=mod[0]*mod[1];
long long f[N],g[N],f1[N],g1[N],h[22][N],W[2][N],ny;
int a[N],n,q;
long long poww(long long x,int y,int z)
{
long long s=1;
for(;y;y>>=1,x=x*x%mod[z])
if(y&1) s=s*x%mod[z];
return s;
}
long long mul(long long x,int y)
{
long long s=0;
for(;y;y>>=1,x=(x+x)%M)
if(y&1) s=(s+x)%M;
return s;
}
void NTT(long long *f,int len,int type,int z)
{
for(int i=0,p=0;i<len;i++)
{
if(i<p) swap(f[i],f[p]);
for(int j=len>>1;(p^=j)<j;j>>=1);
}
for(int i=2;i<=len;i<<=1)
{
int half=i>>1,pe=len/i;
for(int j=0;j<half;j++)
{
long long w=!type?W[z][pe*j]:W[z][len-pe*j];
for(int k=j;k<len;k+=i)
{
long long x=f[k],y=w*f[k+half]%mod[z];
f[k]=(x+y)%mod[z],f[k+half]=(x-y+mod[z])%mod[z];
}
}
}
if(type)
{
ny=poww(len,mod[z]-2,z);
for(int i=0;i<len;i++) f[i]=f[i]*ny%mod[z];
}
}
long long CRT(int i)
{
long long x0=poww(mod[1],mod[0]-2,0),x1=poww(mod[0],mod[1]-2,1);
return (mul(f[i]*mod[1]%M,x0%M)+mul(f1[i]*mod[0]%M,x1%M))%M%mo;
}
void dc(int l,int r,int deep)
{
if(l==r)
{
h[deep][0]=1,h[deep][1]=a[l]%mo;
return;
}
int mid=(l+r)>>1,fn;
for(fn=1;fn<=r-l+1;fn<<=1); dc(l,mid,deep+1); for(int i=0;i<fn;i++) h[deep][i]=h[deep+1][i],h[deep+1][i]=0; dc(mid+1,r,deep+1); W[0][0]=W[1][0]=1,W[0][1]=poww(3,(mod[0]-1)/fn,0),W[1][1]=poww(3,(mod[1]-1)/fn,1);
for(int i=2;i<=fn;i++) W[0][i]=W[0][i-1]*W[0][1]%mod[0],W[1][i]=W[1][i-1]*W[1][1]%mod[1]; for(int i=0;i<fn;i++) f[i]=f1[i]=g[i]=g1[i]=0;
for(int i=0;i<=mid-l+1;i++) f[i]=f1[i]=h[deep][i];
for(int i=0;i<fn;i++) h[deep][i]=0;
for(int i=0;i<=r-mid;i++) g[i]=g1[i]=h[deep+1][i];
for(int i=0;i<fn;i++) h[deep+1][i]=0; NTT(f,fn,0,0),NTT(f1,fn,0,1);
NTT(g,fn,0,0),NTT(g1,fn,0,1);
for(int i=0;i<fn;i++) f[i]=f[i]*g[i]%mod[0],f1[i]=f1[i]*g1[i]%mod[1];
NTT(f,fn,1,0),NTT(f1,fn,1,1); for(int i=0;i<fn;i++) h[deep][i]=CRT(i);
}
int main()
{
scanf("%d%d",&n,&q);
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
dc(1,n,0);
for(int x;q--;)
{
scanf("%d",&x);
printf("%lld\n",h[0][x]);
}
}

快速数论变换NTT模板的更多相关文章

  1. Algorithm: 多项式乘法 Polynomial Multiplication: 快速傅里叶变换 FFT / 快速数论变换 NTT

    Intro: 本篇博客将会从朴素乘法讲起,经过分治乘法,到达FFT和NTT 旨在能够让读者(也让自己)充分理解其思想 模板题入口:洛谷 P3803 [模板]多项式乘法(FFT) 朴素乘法 约定:两个多 ...

  2. 【算法】快速数论变换(NTT)初探

    [简介] 快速傅里叶变换(FFT)运用了单位复根的性质减少了运算,但是每个复数系数的实部和虚部是一个余弦和正弦函数,因此系数都是浮点数,而浮点数的运算速度较慢且可能产生误差等精度问题,因此提出了以数论 ...

  3. 模板 - 数学 - 多项式 - 快速数论变换/NTT

    Huffman分治的NTT,常数一般.使用的时候把多项式的系数们放进vector里面,然后调用solve就可以得到它们的乘积.注意这里默认最大长度是1e6,可能需要改变. #include<bi ...

  4. [快速数论变换 NTT]

    先粘一个模板.这是求高精度乘法的 #include <bits/stdc++.h> #define maxn 1010 using namespace std; char s[maxn]; ...

  5. JZYZOJ 2041 快速数论变换 NTT 多项式

    http://172.20.6.3/Problem_Show.asp?id=2041 https://blog.csdn.net/ggn_2015/article/details/68922404 代 ...

  6. 快速数论变换(NTT)小结

    NTT 在FFT中,我们需要用到复数,复数虽然很神奇,但是它也有自己的局限性--需要用double类型计算,精度太低 那有没有什么东西能够代替复数且解决精度问题呢? 这个东西,叫原根 原根 阶 若\( ...

  7. 从傅里叶变换(FFT)到数论变换(NTT)

    FFT可以用来计算多项式乘法,但是复数的运算中含有大量的浮点数,精度较低.对于只有整数参与运算的多项式,有时,\(\text{NTT(Number-Theoretic Transform)}\)会是更 ...

  8. 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/常用套路【入门】

    原文链接https://www.cnblogs.com/zhouzhendong/p/Fast-Fourier-Transform.html 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/ ...

  9. 「算法笔记」快速数论变换(NTT)

    一.简介 前置知识:多项式乘法与 FFT. FFT 涉及大量 double 类型数据操作和 \(\sin,\cos\) 运算,会产生误差.快速数论变换(Number Theoretic Transfo ...

随机推荐

  1. 【重启C++】 关于 【类】

    1.什么是抽象类 带有纯虚函数成员的类,称为抽象类.抽象类不能被实例化,因为如果能实例化,调用这个纯虚的成员函数时怎么处理. 2.什么是纯虚函数 纯虚函数是在声明虚函数时被“初始化”为0的函数.声明纯 ...

  2. Magazine Delivery(POJ1695)【DP】

    题意:要求用三辆车往n座城市投递货物,起点都在一号城市,每辆车可以载任意数量的货物,投递顺序必须与城市编号递增序一致,并且,每次同时都只能有一辆车在跑路.求最短总路径之和. 思路:每时每刻,能够充分决 ...

  3. 分词搜索 sphinx3.1.1+php+mysql

    sphinx3.1.1的安装与使用 下载sphinx3.1.1 wget http://sphinxsearch.com/files/sphinx-3.1.1-612d99f-linux-amd64. ...

  4. 小白简单快速搭建lnmp环境(centos7)

    本来想着自己搭建lnmp,由于php包下载不下来因此这次本人使用的lnmp一键包搭建的环境(很遗憾还没有php7.3.5)很详细并且方便快捷网址https://lnmp.org/install.htm ...

  5. PHP 协程:Go + Chan + Defer

    Swoole4为PHP语言提供了强大的CSP协程编程模式.底层提供了3个关键词,可以方便地实现各类功能. Swoole4提供的PHP协程语法借鉴自Golang,在此向GO开发组致敬 PHP+Swool ...

  6. 01docker基本概念

    docker基本概念 官方文档URL:https://docs.docker.com/ 1.Docker的构想是要实现"Build, Ship and Run Any App, Anywhe ...

  7. ccpc湘潭邀请赛 Partial Sum

    选定最多m的区间,使区间和的绝对值最大.但是左右端点不能重复选取 首先涉及到区间和的问题,就应该想到用前缀和去优化 这里对前缀和排序 然后贪心的去选取最大.次大 (比赛的时候脑子堵的很,没想出来 可惜 ...

  8. 空格 ACSII码 160 32

    ascii160和ascii32都表示空格,但是在IE里,160就不是显示空格,firefox里会显示空格,32不管是firefox里,还是IE里都显示空格.

  9. Eclipse错误提示: Symbol 'xxxx' could not be resolved

    在eclipse中安装maven(网上资源):https://zhinan.sogou.com/guide/detail/?id=1610049267 项目名 右键->configure-> ...

  10. C#进阶之WebAPI(二)

    今天学习一下:WebAPI如何使用呢? 首先我们打开vs新建一个WebAPI项目,可以看到一共有这些文件夹目录 首先了解一下这些文件夹/文件的意义(按照程序启动的流程,相关的配置项就不说了), Glo ...