首页 > 其他 > 详细

Pow(x, n)

时间:2015-04-20 22:28:58      阅读:258      评论:0      收藏:0      [点我收藏+]
/*
    题意:实现pow(x,n)函数
    坑: 1>要用矩阵快速幂做
        2>n可能为负数
        3>n可能去INT_MIN所以需要类型转换
*/
class Solution {
public:
    double pow(double x, int n) {
        double res = 1;
        int sign = 0;
        long m = (long)n;
        if(m<0) {
            sign = 1;
            m = 0-m;
        }
        while(m){
            if(m&1){
                res*=x;
            }
            x*=x;
            m>>=1;
        }
        return sign ?1.0/res:res;
    }
};

 

Pow(x, n)

原文:http://www.cnblogs.com/llei1573/p/4442648.html

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