首页 > 代码库 > 【leetcode刷题笔记】Pow(x, n)
【leetcode刷题笔记】Pow(x, n)
Implement pow(x, n).
题解:注意两点:
- 普通的递归把n降为n-1会超时,要用二分的方法,每次把xn = x[n/2] * x[n/2] * xn-[n/2]*2, [n/2]表示n除以2下取整。
- n有可能取负数,负数的时候,先计算pow(x,-n),然后返回1/pow(x,-n);
代码如下:
1 public class Solution { 2 public double pow(double x, int n) { 3 if(n == 0) 4 return 1; 5 if(n == 1) 6 return x; 7 8 boolean isNeg = false; 9 10 //if n is negative,we first caculate 1/pow(x,n) = pow(x,-n)11 if(n<0){12 isNeg = true;13 n *= -1;14 }15 16 //binary17 int mid = n /2;18 int left = n - mid*2;19 double front = pow(x, mid);20 double end = pow(x, left);21 22 if(isNeg)23 return 1/(front*front*end);24 else {25 return front*front*end;26 }27 }28 }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。