• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C++快速幂运算

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

1.概念:快速幂运算也叫反复平方法。顾名思义,算法就蕴含在名字中。

2.原理:

    假设要求x^n,如果n = 2^k,那么原题可以很轻松的表示为:x^n = ((x^2)^2)^2…。这样只要做k次平方运算就能解决,时间复杂度就从O(n)下降到log(n)。

    由上面的分析可知,只要幂运算的幂可以写成2^k的形式,就可以用上面的方法降低时间复杂度。所以我们可以将任意的实数n改写有限个2^k的形式的相加。例如:


如图所示,x^22可以改写成x^16*x^4*x^2。这样我们就可以分别对x^16和x^4以及x^2使用上述方法快速计算结果,最后只要相加就可以了。

3.代码实例:

typedef long long ll;
ll quick_pow(ll x,ll n,ll m){
	ll res = 1;
	while(n > 0){
		if(n & 1)	res = res * x % m;
		x = x * x % m;
		n >>= 1;//相当于n=n/2.详情请参考位移运算符。
	}
	return res;
} 

4.另一种理解方法

  • 当b为偶数时,a^b可以转为a^2的b/2次方
  • 当b为奇数时,a^b可以转为a^2的b/2次方,再乘以a
像这样不断递归下去,每次n都减半,于是可以在n(logn)时间内完成幂运算。

4.2代码实例:

ll q_pow(ll x,ll n,ll m){
	if(n == 0)	return 1;
	ll res = q_pow(x * x % m,n/2,m);
	if(n & 1)	res = res * x % m;
	return res;
}
代码很精简,需要仔细看。其中包含了模运算的相关知识,请自行百度。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap