首页 > 代码库 > [Leetcode] 50 - Pow(x, n)
[Leetcode] 50 - Pow(x, n)
原题链接:https://oj.leetcode.com/problems/powx-n/
1. 首先处理特殊情况,比如0,1,-1
2. 关于普遍情况,考虑x^7 = x^(4 + 2 + 1),注意4,2,1都是2的n次方,所以转化为((x ^ 2) ^ 2) * (x ^ 2) * (x)。更加直观来看,我们可以将指数7看为二进制表示111,每一位从右到左对应的是x ^ 4,x ^ 2,x ^ 1。所以我们可以采取逐步位移指数的方法来计算结果,每次检查当前指数最低位是否为1,是则将之前结果乘以当前的base,每次循环结尾右移,然后计算出下一次的新的base。
class Solution { public: double pow(double x, int n) { if (n == 0) return 1; if (x == 0) return 0; if (x == 1) return 1; if (x == -1) { return (n % 2 ? -1 : 1); } if (n < 0) return 1.0 / pow(x, -n); double base = x; double res = 1; while (n) { if (n & 1) { res *= base; } base *= base; n >>= 1; } return res; } };
[Leetcode] 50 - Pow(x, n)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。