首页 > 代码库 > Pow(x, n) -- LeetCode
Pow(x, n) -- LeetCode
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)
1 class Solution { 2 public: 3 double myPow(double x, int n) { 4 if (n == 0) return 1; 5 int64_t pow = std::abs((int64_t)n); 6 double subPow = myPow(x, pow >> 1); 7 double val = subPow * subPow * (pow & 1 ? x : 1); 8 return n > 0 ? val : 1 / val; 9 }10 };
Pow(x, n) -- LeetCode
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。