1 问题描述
FFT问题解决的是复数域上的卷积。如果现在的问题是这样:给出两个整数数列$Ai,Bj,0\leq i\leq n-1,0\leq j\leq m-1$,以及素数$P$,计算新数列$Ci=(\sum_{k}A_{i-k}B_{k})\%P$。不在$A,B$定义域内的值均为0.NTT就是解决这样在模意义下的卷积问题。

2 预备知识
原根的概念:对于两个正整数$a,m$,如果$Gcd(a,m)=1$,那么存在$d\leq m-1$(比如$\varphi (m)$)使得$a^{d}\%m=1$。如果对于某个g使得在$[1,m-1]$内只有$\varphi (m)$满足$g^{\varphi (m)}\%m=1$,那么g被称作m的原根。比如7的原根是3,因为在1,2,3,4,5,6中只有3^6%7=1。

3 算法描述
NTT的原理与FFT的原理完全相同。即首先我们会将$A,B$通过NTT变换转化成新数列$A^{'},B^{'}$,然后我们有$C_{k}^{'}=A_{k}^{'}B_{k}^{'}$。最后通过NTT逆变换,将$C^{'}$转化成$C$.

FFT变换是这样的:$A_{k}^{'}=\sum_{j=0}^{n-1}A_{j}e^{\frac{2\pi i}{n}kj}=\sum_{j=0}^{n-1}A_{j}w_{n}^{kj}$。

FFT逆变换是这样的:$A_{k}=\frac{1}{n}\sum_{j=0}^{n-1}A_{j}^{'}e^{-\frac{2\pi i}{n}kj}=\frac{1}{n}\sum_{j=0}^{n-1}A_{j}^{'}w_{n}^{-kj}$

$e^{\frac{2\pi i}{n}}$在这里之所以能够使用,是因为它在乘法意义下构成一个群。同理,在模P的系统中,对于乘法来说,$g^{\frac{P-1}{n}}$也构成一个群,类似$(e^{\frac{2\pi i}{n}})^{n}=1$,$(g^{\frac{P-1}{n}})^{n}%P=1$。其中g是P的原根。

因此,NTT变换是: $A_{k}^{'}=\sum_{j=0}^{n-1}A_{j}g^{\frac{P-1}{n}kj}$

NTT逆变换: $A_{k}=\frac{1}{n}\sum_{j=0}^{n-1}A_{j}^{'}g^{-\frac{P-1}{n}kj}=\frac{1}{n}\sum_{j=0}^{n-1}A_{j}^{'}g^{((P-1)-\frac{P-1}{n})kj}$

所以,NTT变换使用的基为$g^{\frac{P-1}{n}}$,NTT逆变换使用的基为$g^{(P-1)-\frac{P-1}{n}}$

这里有一些需要注意的问题。在实际计算时,我们会将整个数列的长度扩展至$2^{K}$次幂,因此在每一次分治时,每个子问题的长度n也都是2的某次幂。而这里,必须要保证n能够整除$P-1$,所以若$P=c*2^t+1$,其中$c$为奇数。那么一定要满足$t\geq K$

NTT的更多相关文章

  1. Tsinsen A1493 城市规划(DP + CDQ分治 + NTT)

    题目 Source http://www.tsinsen.com/A1493 Description 刚刚解决完电力网络的问题, 阿狸又被领导的任务给难住了. 刚才说过, 阿狸的国家有n个城市, 现在 ...

  2. HDU5322 Hope(DP + CDQ分治 + NTT)

    题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5322 Description Hope is a good thing, which can ...

  3. Codeforces632E Thief in a Shop(NTT + 快速幂)

    题目 Source http://codeforces.com/contest/632/problem/E Description A thief made his way to a shop. As ...

  4. hihoCoder1388 Periodic Signal(2016北京网赛F:NTT)

    题目 Source http://hihocoder.com/problemset/problem/1388 Description Profess X is an expert in signal ...

  5. hihocoder #1388 : Periodic Signal NTT&FFT

    传送门:hihocoder #1388 : Periodic Signal 先来几个大牛传送门:  (模板) NTT long long 版 解法一:因为我们知道FFT会精度不够,所以坚持用NTT,但 ...

  6. FFT,NTT 专题

    学习傅里叶的基本性质及其代码,可以参考大神理解 还有 ACdream 的博客 贴一下NTT的模板: using namespace std; typedef long long ll; int n; ...

  7. [快速数论变换 NTT]

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

  8. HDU5829 NTT

    以下这份代码并没有过.但感觉没有问题.不是蜜汁WA就是蜜汁T. #include <cstdio> #include <iostream> #include <cstri ...

  9. NTT【51nod】1514 美妙的序列

    题意:1~n 的全排列中,有多少个排列满足任意从中间切成两段后,左边段的最大值大于右边段的最小值? 例如:n为3时有3种 2 3 1 3 1 2 3 2 1 解释:比如 2 3 1 (2) (3 1) ...

随机推荐

  1. Microsoft.Jet.OLEDB.4.0和Microsoft.ACE.OLEDB.12.0的区别

    Microsoft.Jet.OLEDB.4.0和Microsoft.ACE.OLEDB.12.0的区别 时间 2012-12-19 20:30:12  CSDN博客原文  http://blog.cs ...

  2. 夺命雷公狗---node.js---20之项目的构建在node+express+mongo的博客项目5mongodb在项目中实现添加数据

    我们上一步就引入了mongodb了,那么下一步就要开始写添加数据了,不过有个前提是先将表单的数据处理好: 最基本的这部现在已经成功了,因为最基本的这步就是先将表单处的提交方式和提交地址给处理好,这里和 ...

  3. fault coverage enhancement

    在pseudo-random test中,由于random pattern resistant的特性,fault coverage不是sufficient的, 所以会有一些办法来进行coverage的 ...

  4. JSP-02- 使用JSP实现输出

    二. 使用JSP实现输出 JSP的页面构成: 静态内容.指令.表达式.Scriptlet.声明.动作.注释 Jsp脚本: 表达式.Scriptlet.声明 表达式: <%=  内容  %> ...

  5. 【RoR win32】新rails运行后0.0.0.0:3000不能访问

    在浏览器中使用127.0.0.1:3000来访问

  6. session_start()一些问题

    session问题集锦 对于PHP的session功能,始终找不到合适的答案,尤其是一些错误,还有一些没有错误的结果,最可怕的就是后者,一直为许多的初学者为难.就连有些老手,有时都被搞得莫名其妙.本文 ...

  7. 用jQuery创建HTML中不存在的标签元素碰到的问题

    如果你自定义了一个标签,比如<aaa></aaa> 用jQuery的写法,比如var custom_element = $('<aaa class="ee&qu ...

  8. Linode 优惠码

    Linode 是最好的vps $10的优惠码 Linode10,推荐码:bc7852453e280eee5a8ef045c5ab54ca091c8021 链接https://www.linode.co ...

  9. 使用javascript判断浏览器对css3的支持情况【译】

    Quick Tip: Detect CSS3 Support in Browsers with JavaScript Jeffrey Way on Nov 15th 2010  步骤 1 首先我们要确 ...

  10. drupal 做301跳转(删除url里的www), 关键代码 可用到任何网站

    //hook_init(); function ex_init(){ //删除 url 前面的 www if (substr($_SERVER['HTTP_HOST'],0,3) == 'www'){ ...