首页 > 其他 > 详细

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

时间:2015-10-14 10:24:00      阅读:241      评论: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
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!