JZ16 数值的整数次方
描述
实现函数 double Power(double base, int exponent),求base的exponent次方。
注意:
1.保证base和exponent不同时为0。
2.不得使用库函数,同时不需要考虑大数问题
3.有特殊判题,不用考虑小数点后面0的位数。
方法1
思路
既然是求次方,那我们做不断累乘就可以了,重点是处理负的次方数
具体做法:
step 1:先处理次方数为负数的情况,将底数化为分数解决。
step 2:遍历次方数的次数,不断累乘底数。
代码
public double Power(double base, int exponent) {
if (exponent < 0) {
base = 1 / base;
exponent = -exponent;
}
double res = 1.0;
for (int i = 0; i < exponent; i++) {
res *= base;
}
return res;
}
方法2
思路
计算幂运算,我们还可以使用快速幂快速计算。 如果我们要计算5^10,常规的算法是5∗5=25,然后再25∗5=125,如此往下,一共是9次运算,即n−1次。
但是我们可以考虑这样:5∗5=25(二次)、25∗25=625(四次)、625∗625=...(八次),这是一个二分的思维,运算次数缩减到了log2n次
具体做法:
step 1:先处理次方数为负数的情况,将底数化为分数解决。
step 2:使用快速幂计算次方:将已乘出来的部分求次方,可以每次缩小一半要求的次方数。
代码
package mid.JZ16数值的整数次方;
public class Solution {
/*public double Power(double base, int exponent) {
if (exponent < 0) {
base = 1 / base;
exponent = -exponent;
}
double res = 1.0;
for (int i = 0; i < exponent; i++) {
res *= base;
}
return res;
}*/
public double Power(double base, int exponent) {
if (exponent < 0) {
base = 1 / base;
exponent = -exponent;
}
return Pow(base, exponent);
}
public double Pow(double base, int exponent) {
double res = 1.0;
while (exponent != 0) {
if ((exponent & 1) != 0) {
res *= base;
}
base *= base;
exponent = exponent >> 1;
}
return res;
}
public static void main(String[] args) {
new Solution().Power(5, 10);
}
}