二分求幂,最初是在剑指offer上看到,书中给出了递归的代码,后来在王道机试指南上再次看到,那上面给出了非递归的代码。
二分求幂的原理如图:
剑指offer上的递归代码如下:
double powerWithUnsignedExponent(double base,unsigned int exponent)
{
if(exponent==0)
return 1;
if(exponent==1)
return base;
double result=powerWithUnsignedExponent(base,exponent>>1);//exponent>>1即exponent/2
result*=result;
if(exponent & 0x1==1)//a & 0x1相当于a%2
result*=base;
return result;
}王道书上的非递归代码如下:
int power(int a,int b)
{
int ans=1;
while(b!=0)
{
if(b%2==1)
ans*=a;
b/=2;
a*=a;
}
return ans;
}
本文介绍了二分求幂算法的两种实现方式:递归与非递归。递归方式来源于《剑指offer》,通过不断将指数折半来减少计算次数;非递归方式来自王道计算机考研指南,同样采用指数折半的策略,但使用循环而非递归来实现。
1785

被折叠的 条评论
为什么被折叠?



