首页 > 其他 > 详细

Leetcode:Pow(x,n)

时间:2014-06-21 07:26:24      阅读:310      评论:0      收藏:0      [点我收藏+]

Description: Implement pow(xn).

分析: 求幂次运算,典型的分治算法来解。 因为pow(x,n/2)*pow(x,n/2) 有着重复运算,分治法就会非常快O(log n)

 1 class Solution {
 2 public:
 3     double findval(double x,int n)
 4     {
 5         if(n==0) return 1;
 6         if(n==1) return x;
 7         double value = pow(x,n/2);
 8         if(n%2) return value*value*x;
 9         else return value*value;
10     }
11     double pow(double x, int n) {
12         bool flag = false;
13         if(n<0)
14         {
15             n=-n;
16             flag = true;
17         }
18         double value = findval(x,n);
19         if(flag) return 1/value;
20         else return value;
21         
22     }
23 };

 

Leetcode:Pow(x,n),布布扣,bubuko.com

Leetcode:Pow(x,n)

原文:http://www.cnblogs.com/soyscut/p/3795417.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!