NTT小结及原根求法

Posted y2823774827y

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了NTT小结及原根求法相关的知识,希望对你有一定的参考价值。

注意

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

与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小结及原根求法的主要内容,如果未能解决你的问题,请参考以下文章

NTT

NTT注意事项

各种友(e)善(xin)数论总集(未完待续),从入门到绝望

NTT中可用素数模数原根表

[BZOJ3992][SDOI2015]序列统计(DP+原根+NTT)

UOJ #86 mx的组合数 (数位DP+NTT+原根优化)