二分求幂算法

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;
}
朋友们,虽然这个世界日益浮躁起来,只要能够为了当时纯粹的梦想和感动坚持努力下去,不管其它人怎么样,我们也能够保持自己的本色走下去。

浙公网安备 33010602011771号