我试图在不使用 / % * 问题的情况下使用该公式a/b = e^(ln a - ln b)
来解决臭名昭著的Divide 2 Integers
问题,但是对于某些测试用例,(dividend=Integer.MAX_VALUE or MIN_VALUE and divisor=1)
我的解决方案失败了。
为什么会失败?
[编辑]:我为该测试用例得到的答案是(MAX-1 or MIN+1)
. 我想知道为什么会这样。
public int divide(int dividend, int divisor) {
boolean neg = false;
if ((dividend < 0 && divisor > 0) || (dividend > 0 && divisor < 0))
neg = true;
long a = dividend;
a = Math.abs(a);
long b = divisor;
b = Math.abs(b);
double res = Math.pow(Math.E, Math.log(a) - Math.log(b));
int ans = Math.floor(res);
return neg ? -ans : ans;
}