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

快速幂介绍及其模板

时间:2016-10-31 22:11:04      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:str   复杂度   思想   class   个数   pre   问题   log   div   

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;
}

  

快速幂介绍及其模板

标签:str   复杂度   思想   class   个数   pre   问题   log   div   

原文地址:http://www.cnblogs.com/td15980891505/p/6017203.html

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