$umm$先预警下想入门$FFT$就不要康我滴学习笔记了,,, 就,我学习笔记基本上是我大概$get$之后通过写$blog$加强理解加深记忆这样儿的,有些姿势点我可能会直接$skip$什么的,所以对除了我以外的所有人都十分不友好…
问题: 已知A[], B[], 求C[],使: 定义C是A,B的卷积,例如多项式乘法等. 朴素做法是按照定义枚举i和j,但这样时间复杂度是O(n2). 能不能使时间复杂度降下来呢? 点值表示法: 我们把A,B,C看作表达式. 即: A(x)=a0 + a1* x + a2 * x2 +... 将A={(x1,A(x1)), (x2,A(x2)), (x3,A(x3))...}叫做A的点值表示法. 那么使用点值表示法做多项式乘法就很简单了:对应项相乘. 那么,如何将A和B转换成点值表示法,再将C转…
目录 FFT 系数表示法 点值表示法 复数 DFT(离散傅里叶变换) 单位根的性质 FFT(快速傅里叶变换) IFFT(快速傅里叶逆变换) NTT 阶 原根 扩展知识 FFT 参考blog: 十分简明易懂的FFT(快速傅里叶变换) 快速傅里叶变换(FFT)详解 (下面的图片是来自于这2篇博客里面的,仔细看可以发现右下角有水印--) 系数表示法 一个一元\(n\)次多项式\(f(x)\)可以被表示为:\[f(x) = \sum_{i = 0}^{n}a_{i}x^{i}\] 即用\(i\)次项的系…
问题: 已知$A=a_{0..n-1}$, $B=b_{0..n-1}$, 求$C=c_{0..2n-2}$,使: $$c_i = \sum_{j=0}^ia_jb_{i-j}$$ 定义$C$是$A$,$B$的卷积,记作 $$C = A * B$$ 例如多项式乘法等. 朴素做法是按照定义枚举$i$和$j$,但这样时间复杂度是$O(n^2)$. 能不能使时间复杂度降下来呢? 点值表示法: 我们把$A$,$B$,$C$看作多项式. 即: $$A(x) = \sum_{i=0}^{n-1}a_ix^i…
实在是 美丽的数学啊 关于傅里叶变换的博客 讲的很细致 图片非常易于理解http://blog.jobbole.com/70549/ 大概能明白傅里叶变换是干吗的了 但是还是不能明白为什么用傅里叶变换来算多项式求和 在多项式中,DFT就是系数表式转换成点值表示的过程. 我们熟知的是多项式的系数表示法,通过给定一组  来确定一个唯一的多项式: 而多项式还可以有另一种表示法,称为点值表示法: 其中 可以证明,对一组互不相同的该方法也可以唯一地表示一个多项式. 为什么要引入点值表示法这个并不"直观&q…
本文只讨论FFT在信息学奥赛中的应用 文中内容均为个人理解,如有错误请指出,不胜感激 前言 先解释几个比较容易混淆的缩写吧 DFT:离散傅里叶变换—>$O(n^2)$计算多项式乘法 FFT:快速傅里叶变换—>$O(n*\log(n)$计算多项式乘法 FNTT/NTT:快速傅里叶变换的优化版—>优化常数及误差 FWT:快速沃尔什变换—>利用类似FFT的东西解决一类卷积问题 MTT:毛爷爷的FFT—>非常nb/任意模数 FMT 快速莫比乌斯变化—>感谢stump提供 多项式…
FFTFFT·Fast  Fourier  TransformationFast  Fourier  Transformation快速傅立叶变换 P3803 [模板]多项式乘法(FFT) 参考上文 首先介绍, 欧拉公式: 公式描述:公式中e是自然对数的底,i是虚数单位. 快速傅里叶变换(FFT)详解 前言: DFT:离散傅里叶变换—>O(n2)计算多项式乘法 FFT:快速傅里叶变换—>O(n∗log(n)O(n∗log⁡(n)计算多项式乘法 FNTT/NTT:快速傅里叶变换的优化版—>优…
前言 啊摸鱼真爽哈哈哈哈哈哈 这个假期努力多更几篇( 理解本算法需对一些< 常 用 >数学概念比较清楚,如复数.虚数.三角函数等(不会的自己查去(其实就是懒得写了(¬︿̫̿¬☆) 整理了一点点资料(确信 本文仅为作者的总结与完善和本人的理解与观点,有任何误导性错误请多多指出 [WARNING]文笔极差,文章极度啰嗦且可能有些迷惑hhh,尽力了_(:з)∠)_ 概述(可略过 离散傅里叶变换(Discrete Fourier Transform,缩写为 DFT),是傅里叶变换在时域和频域上都呈离散…
引入 可能有不少OIer都知道FFT这个神奇的算法, 通过一系列玄学的变化就可以在 $O(nlog(n))$ 的总时间复杂度内计算出两个向量的卷积, 而代码量却非常小. 博主一年半前曾经因COGS的一道叫做"神秘的常数 $\pi$"的题目而去学习过FFT, 但是基本就是照着板子打打完并不知道自己在写些什么鬼畜的东西OwO 不过...博主这几天突然照着算法导论自己看了一遍发现自己似乎突然意识到了什么OwO然后就打了一道板子题还1A了OwO再加上午考试差点AK以及日更频率即将不保于是就有了…
FWT快速沃尔什变换学习笔记 1.FWT用来干啥啊 回忆一下多项式的卷积\(C_k=\sum_{i+j=k}A_i*B_j\) 我们可以用\(FFT\)来做. 甚至在一些特殊情况下,我们\(C_k=\sum_{i*j=k}A_i*B_j\)也能做(SDOI2015 序列统计). 但是,如果我们把操作符换一下呢? 比如这样? \(C_k=\sum_{i|j=k}A_i*B_j\) \(C_k=\sum_{i\&j=k}A_i*B_j\) \(C_k=\sum_{i\wedge j=k}A_i*B_…