Implement pow(x, n).
用递归吧,虽然我尝试了用非递归,但是没有成功。
class Solution {
public:
double powinternal(double x, int n) {
if(n == 0) return 1;
double half = powinternal(x, n / 2);
if(n % 2 == 0) {
return half * half;
}
else {
return half * half * x;
}
}
double pow(double x, int n) {
if(n > 0)
return powinternal(x, n);
else
return 1.0 / powinternal(x, -n);
}
};
本文介绍了一种使用递归方式实现幂运算的方法。通过将问题分解为更小规模的子问题来减少计算次数,该方法有效地提高了计算效率。具体地,当指数为偶数时,可以通过先计算一半指数的幂再平方得到结果;当指数为奇数时,则还需要额外乘以基数。
314

被折叠的 条评论
为什么被折叠?



