幂运算的O(lgn)算法

对于幂运算 a^b,最原始的方法是用for循环一遍:

double powRaw(double base,int n)
{
	double r = 1;
	for(int i=1;i<=n;i++)
		r = r*base;
	return r;
}

考虑如下下面的事实:

对于r = a^b,若b为偶数,那么r = a^(b/2)·a^(b/2);若b为奇数,那么r = a^((n-1)/2)·a^((n-1)/2)·a。利用这个事实可以得到如下的递归解法:

double pow(double base,int n)
{
	if (n == 0)
		return 1;
	if (n == 1)
		return base;
	double t = pow(base,n >> 1);
	if (n & 0x1) 
		return t*t*base;
	else
		return t*t;
}

另外,b用二进制表示,那么a^b可以看到r = a^(1011) = a^(1000)·a^(10)·a^(1),那么可以得到其非递归算法如下:

double power(double base,unsigned int n)
{
	double  r = 1;
	while(n)
	{
		if (n & 0x1)
			r *= base;
		n = n >> 1;
		base *= base;
	}
	return r;
}
参考文章:

http://blog.youkuaiyun.com/prstaxy/article/details/8740838

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值