【leetcode】(python) 50. Pow(x, n)权

Description

  1. 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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值