题目
给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。
保证base和exponent不同时为0。不得使用库函数,同时不需要考虑大数问题,也不用考虑小数点后面0的位数。
思路
我的第一个步骤其实是多余的,题目已经保证了base和exponent不同时为0,故只用考虑整数exponent,当exponent=0,则result = 1,当exponent>0,则result = exponent个base相乘,当exponent<0,则result = 1/exponent个base相乘。
代码
public class Solution {
public double Power(double base, int exponent) {
double result = base;
//base为0,exponent不能为0或者负数
//base为0,exponent取任意正数结果均为0
if(base == 0.0){
return 0.0;
}else if(base != 0 && exponent == 0){
return 1.0;
}else if(base != 0 && exponent > 0){
for(int i=1;i<exponent;i++){
result*=base;
}
return result;
}else{
int other = -exponent;
for(int i=1;i<other;i++){
result*=base;
}
return 1/result;
}
}
} //这是别人的解法
public class Solution {
public double Power(double base, int exponent) {
if(exponent == 0) return 1;
else if(exponent>0) return base * Power(base,exponent-1);
else return 1/base*Power(base,exponent+1);
}
}
京公网安备 11010502036488号