Description
- Pow(x, n) Medium
Implement pow(x, n), which calculates x raised to the power n (xn).
Example
-
Example 1:
Input: 2.00000, 10
Output: 1024.00000 -
Example 2:
Input: 2.10000, 3
Output: 9.26100 -
Example 3:
Input: 2.00000, -2
Output: 0.25000
Explanation: 2-2 = 1/22 = 1/4 = 0.25 -
Note:
-100.0 < x < 100.0
n is a 32-bit signed integer, within the range [−231, 231 − 1]
题意
就是求x的n次方
抖个机灵,直接用python中的pow函数竟然也能AC
class Solution:
def myPow(self, x: float, n: int) -> float:
return pow(x, n)
思路1 递归
基本思路就是分类讨论:n=0时直接返回 1,n<0时也就是示例3的情况,使x = 1/x再使n值取正就行,n>0时又分为n为奇数和偶数,为奇数时x的n次方可表示为x乘x的n-1次方,为偶数时x的n次方可表示为x的平方的n/2次方。
code
class Solution:
def myPow(self, x: float, n: int) -> float:
if n == 0:
return 1
if n < 0:
x = 1 / x
n = - n
if n % 2 == 1:
return x * self.myPow(x, n-1)
return self.myPow(x * x, n/2)
思路2 二进制移位
其实基本思路跟递归差不多,不同的是这里n值在减小的过程中用的是二进制向右移一位。
【笔记】>> 是移位运算符,比如 3>>1 就是将3的二进制( 11)向右移移位变成1,低位自动消失。
n>>=1 就类似于 n+=1; 等同于n = n>>1 ,就是n变成n向右移一位的那个数。
code
class Solution:
def myPow(self, x: float, n: int) -> float:
if n == 0:
return 1
if n < 0:
x = 1 / x
n = - n
res = 1
while n>0:
if n % 2 == 1:
res *= x
n >>=1
x *= x
return res