模拟小学乘法:最简单的乘法竖式手算的累加型;
分治乘法:最简单的是Karatsuba乘法,一般化以后有Toom-Cook乘法;
快速傅里叶变换FFT:(为了避免精度问题,可以改用快速数论变换FNTT),时间复杂度O(N lgN lglgN)。具体可参照Schönhage–Strassen algorithm;
中国剩余定理:把每个数分解到一些互素的模上,然后每个同余方程对应乘起来就行;
Furer’s algorithm:在渐进意义上FNTT还快的算法。不过好像不太实用,本文就不作介绍了。大家可以参考维基百科Fürer’s algorithm
1.大数模板
http://blog.csdn.net/sunnyyoona/article/details/43234889
http://blog.csdn.net/u010983881/article/details/77503519
https://mooc.guokr.com/platform/Coursera/
本文介绍了几种处理大数乘法的有效算法,包括基本的累加型乘法、分治思想的Karatsuba乘法及Toom-Cook乘法、利用快速傅里叶变换的Schönhage–Strassen算法等。此外还提到了基于中国剩余定理的方法以及Furer’s algorithm。
4万+

被折叠的 条评论
为什么被折叠?



