剑指offer面试题11 数值的整数次方的Java代码实现

数值的整数次方的Java代码实现

剑指offer这本书不错。以下是我对这道题的Java代码实现
/**
	 * 剑指offer中面试题11:数值的整数次方double power(double base,int exponent)
	 * 注意事项:
	 * 1.指数exponent可能为正数,负数和0。数值的负数次方,可以先求绝对值,然后求倒数(但是底数为0异常,查看2)。
	 * 2.底数base可能为0,正数和负数。底数为0时,若此时指数为负数,导致异常。1/0没有意义。
	 * 3.尽量高效的计算乘幂。
	 * 4.出错处理方式有三种:
	 * (1)返回值,不能方便的使用返回结果。
	 * (2)全局变量,用户容易忘记判断,导致潜在的错误。
	 * (3)try catch。有些语言(c语言)不支持,导致性能影响
	 * 5.double和float类型的数值判断为0,不能直接用==0?判断。因为计算机表示小数有误差。
	 * 步骤:
	 * 1.判断exponent是否为负数;
	 * 2.判断base是否为0;
	 * 3.利用数的偶数次方等于其二分之一次方的平方
	 * 
	 * 
	 * @return
	 */
    boolean gInvalidInput=false;
	public double power(double base,int exponent) {
		gInvalidInput=false;//调用全局变量时重新赋值为false,以免值非初始值,导致错误
		
		if(equals(base, 0.0)&&exponent<0)
		{
			gInvalidInput=true;
			return 0.0;
		}
		if(exponent<0)
		{
			int positiveInt=Math.abs(exponent);
			return 1/unsignedIntPower(base, positiveInt);
						
		}
		else
		{
			return unsignedIntPower(base, exponent);
		}
		
	}
	public boolean equals(double base,double other) {
		
		if(((base-other)<0.0000001)||((other-base)>-0.0000001))
		{
			return true;
		}
						
		return false;
	}
	//使用递归的方法
	public double unsignedIntPower(double base,int exponent) {
		if(exponent==0)
			return 1.0;
		if(exponent==1)
			return 1*base;
		double result=unsignedIntPower(base, exponent>>1);
		result *=result;
		//判断exponent是否为偶数,奇数
		if((exponent&0x1)==1)
		{
			//为奇数情况
			result*=base;
		}				
		return result;
		
	}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值