首页
Python
Java
IOS
Andorid
NodeJS
JavaScript
HTML5
【
NTT学习笔记
】的更多相关文章
FFT和NTT学习笔记_基础
FFT和NTT学习笔记 算法导论 参考(贺) http://picks.logdown.com/posts/177631-fast-fourier-transform https://blog.csdn.net/qq_38944163/article/details/81835205 https://www.cnblogs.com/RabbitHu/p/FFT.html [TOC] 概述 目的 以$O(nlg_n)$的时间复杂度计算多项式乘法 多项式的表达 系数表达: \(\{a_0, a_1,…
NTT学习笔记
和\(FFT\)相对应的,把单位根换成了原根,把共轭复数换成了原根的逆元,最后输出的时候记得乘以原\(N\)的逆元即可. #include <bits/stdc++.h> using namespace std; #define LL long long const int MAXN = 3 * 1e6 + 10, P = 998244353, G = 3; LL a[MAXN], b[MAXN]; int N, M, limit = 1, L, r[MAXN], Gi; inline LL…
FFT、NTT学习笔记
参考资料 picks miskcoo menci 胡小兔 unname 自为风月马前卒 上面是FFT的,学完了就来看NTT吧 原根 例题:luogu3803 fft优化后模板 #include <iostream> #include <cstdio> #include <cmath> using namespace std; int n, m, lim=1, rev[2100005]; const double PI=acos(-1.0); struct Complex…
FFT&NTT学习笔记
具体原理就不讲了qwq,毕竟证明我也不太懂 FFT(快速傅立叶变换)&NTT(快速数论变换) FFT //求多项式乘积 //要求多项式A和多项式B的积多项式C //具体操作就是 //DFT(A),DFT(B)->暴力乘积->拉格朗日插值(即IDFT(C))->C //其中DFT表示离散傅里叶变换 //通俗的来说就是用点值表示多项式 //使用神秘单位复数根将时间复杂度降至O(nlogn) //ps:但是常数巨大 //pps:应用非常广泛,非常多题目都要fft or ntt优化,板子…
NTT 学习笔记
引入 \(\tt NTT\) 和 \(\tt FFT\) 有什么不一样呢? 就是 \(\tt NTT\) 是可以用来取模的,而且没有复数带来的精度误差. 最最重要的是据说 \(\tt NTT\) 常数小的很,可以在这一方面吊打 \(\tt FFT\) . 至于对于不用取模的多项式乘法怎么做,可以给他附一个非常大的模数. 但是如果遇到有非整数的系数的多项式还是只能看 \(\tt FFT\) 了. 正文 \(\tt NTT\) 的前置知识比 \(\tt FFT\) 的要简单的多. 原根 对于 \(p…
FFT/NTT 学习笔记
0. 前置芝士 基础群论 复数 \(\mathbb C = \mathbb R[x^2+1]\) 则有 \(i^2+1=(-i)^2+1=0\),\(i \in \mathbb C - \mathbb R\) \(i^0=1;i^1=i;i^2=-1;i^3=-i;i^x=i^{x \bmod 4}(x \in \mathbb Z)\) 定理 0.1(欧拉公式) \(e^{ik} = \cos k + i \sin k\) 证明: (因为这里辛辛苦苦打出来的 \(\sf \LaTeX\) 炸了,…
任意模数NTT学习笔记
这两天有点颓,所以东西学的也很慢...这个一眼就能推出来的活生生卡了我两天.. 说几个细节: 柿子: \[f*g = (\frac{f}{M} +f\%m)*(\frac{g}{M} +g\%m) \] \(M\)通常设置为\(32768\).把上一步的几个韩束化成\(a,b,c,d\)的形式,答案就是: \(M * M * a * c+M * (a * d + b *c) +b * d\) 一看卷积,多搞几次\(FFT\)就过去了. 处处小心膜爆.有效方法如下. #define int lon…
[学习笔记]NTT——快速数论变换
先要学会FFT[学习笔记]FFT——快速傅里叶变换 一.简介 FFT会爆精度.而且浮点数相乘常数比取模还大. 然后NTT横空出世了 虽然单位根是个好东西.但是,我们还有更好的东西 我们先选择一个模数,$const\space int\space p=998244353$ 设g为p的单位根.这里就是3 那么有:$(\omega_n^1)^n = g^{p-1}=1\space mod \space p$ 那么,假设$x=(\omega_n^1)$ 其中一个解可以是:$x=g^{\frac{p-1}…
「学习笔记」FFT 之优化——NTT
目录 「学习笔记」FFT 之优化--NTT 前言 引入 快速数论变换--NTT 一些引申问题及解决方法 三模数 NTT 拆系数 FFT (MTT) 「学习笔记」FFT 之优化--NTT 前言 \(NTT\) 在某种意义上说,应该属于 \(FFT\) 的一种优化. --因而必备知识肯定要有 \(FFT\) 啦... 如果不知道 \(FFT\) 的大佬可以走这里 引入 在 \(FFT\) 中,为了能计算单位原根 \(\omega\) ,我们使用了 \(\text{C++}\) 的 math 库中的…
再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Bluestein算法+分治FFT+FFT的优化+任意模数NTT)
再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Bluestein算法+分治FFT+FFT的优化+任意模数NTT) 目录 再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Bluestein算法+分治FFT+FFT的优化+任意模数NTT) 写在前面 一些约定 循环卷积 DFT卷积的本质 Bluestein's Algorithm 例题 分治FFT 例题 FFT的弱常数优化 复杂算式中减少FFT次数 例题 利用循环卷积 小范围暴力 例题 快速幂乘法次数的优化 FFT的强常数优化 DF…