SPOJ - VFMUL:https://vjudge.net/problem/SPOJ-VFMUL 这是一道FFT求高精度的模板题. 参考:https://www.cnblogs.com/RabbitHu/p/FFT.html #include <algorithm> #include <iterator> #include <iostream> #include <cstring> #include <cstdlib> #include &l…
题目链接:VFMUL - Very Fast Multiplication Description Multiply the given numbers. Input n [the number of multiplications <= 101] l1 l2 [numbers to multiply (at most 300000 decimal digits each)] Text grouped in [ ] does not appear in the input file. Outpu…
P1919 FFT加速高精度乘法 传送门:https://www.luogu.org/problemnew/show/P1919 题意: 给出两个n位10进制整数x和y,你需要计算x*y. 题解: 对于十进制数我们可以将其转换成 \(a0*10^0+a1*10^1+a2*10^2...an*10^n\) 那么对于两个数,我们就可以求出两个的系数表示后得到a的点乘式和b的点乘式 最后得到的答案就是a和b的多项式的系数,这个问题O(n)扫一遍, 处理一下输出即可 代码: #include <set>…
你应该知道$FFT$是用来处理多项式乘法的吧. 那么高精度乘法和多项式乘法有什么关系呢? 观察这样一个$20$位高精度整数$11111111111111111111$ 我们可以把它处理成这样的形式:$\sum_{i=0}^{19}1\times10^i$ 这样就变成了一个多项式了! 直接上代码吧(以$Luogu\ P1919$为例): #include <cmath> #include <cstdio> #include <algorithm> using std::s…
Code: #include <cstdio> #include <algorithm> #include <cmath> #include <cstring> #define setIO(s) freopen(s".in","r",stdin) #define maxn 200000 #define pi 3.1415926535898 using namespace std; int len=1,l,r[maxn&…
A * B Problem Plus Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 9413    Accepted Submission(s): 1468 Problem Description Calculate A * B.   Input Each line will contain two integers A and B.…
题意:计算A*B,A,B均为长度小于50000的整数. 这是FFT在大整数相乘中的一个应用,我本来想用NTT做的,但NTT由于取模很可能取炸,所以base必须设得很小,而且效率也比不上FFT. A和B的存储均用long long,在计算乘积的时候转化成double,计算完成后再转回来即可. 测得base在精度允许范围内最多能开到10000. 把平方和快速幂的函数也写上了,可以当模板用~ #include<bits/stdc++.h> using namespace std; typedef l…
零零星星挖坑几个了,都没填土,实在是欠账太多,闲话少说吧,还是多记录总结一下.今天的主题是围绕convolution和加速 记得之前看过lecun他们组的一篇文章,是fft加速convolution的.按照Convolution Theorem,时域上的卷积可以转成空间域的傅立叶变换进行. lecun的文章就是通过把卷积变成傅立叶变换实现加速的.从实验里看到,加速比2倍左右.目前这部分有代码开源,但是好像并没有merge到caffe中,原因可能是因为加速比例有限,再者消耗空间.猜测主要是加速比例…
题目链接  51nod 算法马拉松 34  Problem D 在这个题中$2$这个质数比较特殊,所以我们先特判$2$的情况,然后仅考虑大于等于$3$的奇数即可. 首先考虑任意一个点对$(i, j)$,满足$1 <= i <= j <= n$ 我们考虑这个点对对答案的贡献. 首先显然$i$和$j$必须有相同的奇偶性,那么$i + j$一定为偶数. 包含这个点对的有效的质数的区间长度为$[j - i + 1, min(i + j - 1, 2n + 1 - i - j)]$中的所有质数.…
学会了FFT之后感觉自己征服了世界! 当然是幻觉... 不过FFT还是很有用的,在优化大规模的动规问题的时候有极大效果. 一般比较凶残的计数动规题都需要FFT(n<=1e9). 下面是高精度乘法的板子. #include<iostream> #include<cstdio> #include<cstdlib> #include<cstring> #include<ctime> #include<cmath> #include&l…