码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode OJ:Pow(x, n) (幂运算)

时间:2015-10-14 10:24:33      阅读:107      评论:0      收藏:0      [点我收藏+]

标签:

Implement pow(xn).

幂运算,简单的方法snag然很好实现,直接循环相乘就可以了,但是这里应该不是那种那么简单,我的做法使用到了一点递归:

 1 class Solution {
 2 public:
 3     double myPow(double x, int n) {
 4         if(n == INT_MIN)
 5                 return 1.0* x/myPow(x, INT_MAX);
 6         if(n < 0)
 7             return 1.0/myPow(x, -n);
 8         else if(n == 0)
 9             return 1.0;
10         double halfRes = myPow(x, n/2);
11         if(n%2)
12             return halfRes * halfRes * x;
13         return halfRes * halfRes;
14     }
15 };

这里有个注意点就是考虑到INT_MIN的情况,做出相应的处理

LeetCode OJ:Pow(x, n) (幂运算)

标签:

原文地址:http://www.cnblogs.com/-wang-cheng/p/4876498.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!