您的位置:首页 > 其它

Power(int base, int exponent) 函数实现

2013-09-30 21:20 274 查看
这个是个高效的算法,时间复杂度为 O(logn)

原理:

a的n次方:



#include<iostream>
#include<cmath>
using namespace std;

double PowerWithUnisgnedExponent(double base ,unsigned int exponent)
{
if(exponent == 0)
return 1;
if(exponent == 1)
return base;

double result = PowerWithUnisgnedExponent(base, exponent >> 1);
result *= result;
if(exponent & 0x1 == 1)
result *=base;
return result;
}

double power(double base, int exponent)
{
double result = PowerWithUnisgnedExponent(base,abs(exponent));
if(exponent < 0)
return 1.0/result;
else
return result;
}

int main()
{
int base = 2;
int exponent = 10;
cout << power(base,exponent);

return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐