题目描述
给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。
C++
/*
功能测试:base=2,exponent=32
边界测试:base=0,exponent=-1 return
base!=0,exponent=1,0,-1
错误输入:
*/
class Solution {
public:
bool g_InvalidInput=false;
double Power(double base, int exponent) {
g_InvalidInput=false;
if(base==0&&exponent<0)
{
g_InvalidInput=true;
return 0.0;
}
int absexponent=exponent;
if(exponent<0)
{
absexponent=-exponent;
}
double result=PowerWithUnsignedExponent(base,absexponent);
if(exponent<0)
{
result=1.0/result;
}
return result;
}
double PowerWithUnsignedExponent(double base,int exponent)
{
double result=1.0;
for(int i=0;i<exponent;i++)
{
result*=base;
}
return result;
}
};
Java
public class Solution {
public double Power(double base, int exponent) {
// 当底数为0,指数为负数时,则抛出异常或者返回0.0
if (equal(base, 0) && exponent < 0) {
return 0.0;
}
// 先对指数进行取绝对值计算
int absExponent = Math.abs(exponent);
double result = powerWithExponent(base, absExponent);
// 判断如果传入的指数是负数,进行取反,否则直接返回
if (exponent < 0) {
result = 1.0 / result;
}
return result;
}
// 计算数值的整数次方
public double powerWithExponent(double base, int absExponent) {
double result = 1.0;
for (int i = 1; i <= absExponent; ++i) {
result *= base;
}
return result;
}
// 判断两个double类型的数值是否相等
public boolean equal(double num1, double num2) {
if ((num1 - num2 > -0.0000001) && (num1 - num2 < 0.0000001)) {
return true;
} else
return false;
}
}
python
# -*- coding:utf-8 -*-
class Solution:
def Power(self, base, exponent):
# write code here
result = 1.0
if exponent >= 0:
for i in range(exponent):
result *= base
else:
for i in range(abs(exponent)):
result *= base
result = 1.0/result
return result