您的位置:首页 > 其它

Pow(x, n) -- LeetCode

2016-08-26 06:59 288 查看
Implement pow(x, n).

思路:n为0时返回1。

之后我们只考虑n为正的情况(n为负时结果为正时的倒数)。之后我们通过二分法来求值。

假如n为偶数,则pow(x, n) = pow(x, n / 2) * pow(x, n / 2)。

假如n为奇数,则pow(x, n) = pow(x, n / 2) * pow(x, n / 2) * x。

因为n为int类型,若n为INT_MIN时转换成正数会溢出,因此我们先将n转换成int64_t。

算法复杂度O(logn)

class Solution {
public:
double myPow(double x, int n) {
if (n == 0) return 1;
int64_t pow = std::abs((int64_t)n);
double subPow = myPow(x, pow >> 1);
double val = subPow * subPow * (pow & 1 ? x : 1);
return n > 0 ? val : 1 / val;
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: