• LeetCode:326(Python)—— 3 的幂


    3 的幂

    概述:给定一个整数,写一个函数来判断它是否是的幂次方。如果是,返回 true ;否则,返回 false 。整数 n3 的幂次方需满足:存在整数 x 使得 n == 3x 

    1. 输入:n = 27
    2. 输出:true
    3. 输入:n = 0
    4. 输出:false
    5. 输入:n = 9
    6. 输出:true
    7. 输入:n = 45
    8. 输出:false

    方法一:约分

    思路:设定一个上限值,然后判断是否被约分即可。

    1. # 约分
    2. # 设定一个上限值,然后判断是否被约分即可。
    3. class Solution:
    4. def isPowerOfThree(self, n: int) -> bool:
    5. return n > 0 and 3 ** 30 % n == 0

    方法二:递归

    思路:设定好边界条件,然后依次递归到最小值,判断即可。

    1. # 递归
    2. # 设定好边界条件,然后依次递归到最小值,判断即可。
    3. class Solution:
    4. def isPowerOfThree(self, n: int) -> bool:
    5. if n <= 0:
    6. return False
    7. while n != 1:
    8. if n % 3 != 0:
    9. return False
    10. n /= 3
    11. return n == 1

    方法三:递归(优化版)

    思路:若被 3 整除,更新原整数,依次循环到 1 判断即可。

    1. # 递归(优化版)
    2. # 若被 3 整除,更新原整数,依次循环到 1 判断即可。
    3. class Solution:
    4. def isPowerOfThree(self, n: int) -> bool:
    5. while n > 0 and n % 3 == 0:
    6. n //= 3
    7. return n == 1

    方法四:暴力循环

    思路:用 math.pow() 方法计算幂值,依次循环判断即可。

    1. # 暴力循环
    2. # math.pow()方法计算幂值,依次循环判断即可。
    3. class Solution:
    4. def isPowerOfThree(self, n: int) -> bool:
    5. for i in range(31):
    6. if math.pow(3, i) == n:
    7. return True
    8. return False

    方法五:暴力循环

    思路:设定一个初始整数,乘以 3 的倍数,然后循环判断即可。

    1. # 暴力循环
    2. # 设定一个初始整数,乘以 3 的倍数,然后循环判断即可。
    3. class Solution:
    4. def isPowerOfThree(self, n: int) -> bool:
    5. ans = 1
    6. while ans < n:
    7. ans *= 3
    8. return ans == n

    总结

    简单题,就要多秀几种方法!

  • 相关阅读:
    工业品商城软件java和PHP哪个好?
    M2DGR 多源多场景 地面机器人SLAM数据集
    【图像重建】基于遗传算法实现二值图像重建附matlab代码
    Android SDK 加壳加固
    概率统计·随机变量的数字特征【数学期望、方差】
    实体链指(3)EL:End-to-End
    【Lua语法】字符串
    操作符——C语言初阶
    Learn-1
    mysql存储地理信息的方法
  • 原文地址:https://blog.csdn.net/m0_61661179/article/details/128213599