Implement pow(x, n).
Use recursion. Note when n is negative.
public class Solution {
public double pow(double x, int n) {
if (n == 0) {
return 1;
}
if (n == 1) {
return x;
}
boolean isNegative = false;
if (n < 0) {
isNegative = true;
n *= -1;
}
double t = pow(x, n / 2);
double res = t * t * pow(x, n - n / 2 * 2);
if (isNegative) {
return 1 / res;
} else {
return res;
}
}
}