码迷,mamicode.com
首页 > 其他好文 > 详细

NTT小结及原根求法

时间:2019-05-06 19:08:43      阅读:146      评论:0      收藏:0      [点我收藏+]

标签:limit   浮点数   快速   证明   误差   span   简单   line   的区别   

注意

由于蒟蒻实在太弱了~^_^~暂时无法完成证明,仅能写出简单版总结

与FFT的区别

\(NTT\)\(FFT\)的代码区别就是把单位根换成了原根,从而实现无精度误差与浮点数的巨大常数

原根具有单位根的所有特点,原根是在特定模数下的定义

对于模数\(p\),原根\(g\)满足:\(~_{i=0}^{p-1}g^i (mod~p)\)均不同

\(type=1,g^{\frac{p-1}{2*mid}};type=-1,\dfrac{1}{g^{\frac{p-1}{2*mid}}}\)代替单位根
最后得到的值除一下\(limit\)

原根

快速求原根:对于模数\(p\)分解质因数,\(p-1=p_1^{k_1}...p_n^{k_n}\),原根\(g\)满足\(~_{i=1}^n g^{\frac{p-1}{p_i}}≠1(mod p)\)

求原根就直接分解\(p-1\),然后\(1\)~\(p\)枚举原根就行,通常原根很小,所以能快速求出

\(w=g^{\frac{p-1}{2*mid}}\)

NTT小结及原根求法

标签:limit   浮点数   快速   证明   误差   span   简单   line   的区别   

原文地址:https://www.cnblogs.com/y2823774827y/p/10670910.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!