快速幂介绍及其模板

Posted 曹孟德

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了快速幂介绍及其模板相关的知识,希望对你有一定的参考价值。

1.数的快速幂问题:

     所谓的快速幂,实际上是快速幂取模的缩写,简单的说,就是快速的求一个幂式的模(余)。在程序设计过程中,经常要去求一些大数对于某个数的余数,为了得到更快、计算范围更大的算法,产生了快速幂取模算法。快速幂实际上是求解形如:an%b这种形式。其中a和n可能会很大。

      普通解法时间复杂度为O(n),而快速幂则是O(logn),其主体思想如下:将n分解为2进制,n =a0*20+a1*21...+at*2t-1然后就可与分开计算了,例如:39=1*20+0*21+0*22+1*23.注意到2k=2*2k-1,于是将复杂度降低为O(logn).

 模板:

LL quik_pow(LL a, LL b, LL n){
	// a^b %n
	LL x(a),d(1);
	while (b > 0){
		if (b & 1) d = d*x%n;
		x = x*x%n;
		b >>= 1;
	}
	return d;
}

  

以上是关于快速幂介绍及其模板的主要内容,如果未能解决你的问题,请参考以下文章

LuoguP1226 模板快速幂||取余运算

模板之矩阵快速幂(luogu P3390模板矩阵快速幂)

快速幂模板

51nod1113(矩阵快速幂模板)

数论——快速幂,模运算及快速幂求逆元

Luogu 题解 P1226 [模板] 快速幂||取余运算