首页 > 其他 > 详细

LeetCode 50: Pow(x, n)

时间:2015-03-24 21:07:57      阅读:170      评论:0      收藏:0      [点我收藏+]

题目描述:

Implement pow(x, n).

思路:

要实现pow函数,当然我们可以递归实现return x*pow(x,n-1). 但是这样存在的问题就是递归的计算中不够优化的问题。更简单的方法是每次二分来实现。这样大大减少了乘法的次数。

中间需要注意以下几个问题:

1.指数是负数

2.溢出的问题

class Solution {
public:
    double pow(double x, int n) {
		if(n==0) return 1;

		double temp = pow(x,n/2);

		if(n&1){
			if(n<0) return 1/x*temp*temp;
			return temp*temp*x;
		} 

		return temp*temp;
	}
};

 

LeetCode 50: Pow(x, n)

原文:http://www.cnblogs.com/xiamaogeng/p/4363852.html

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