• LeetCode:342(Python)—— 4 的幂


    4 的幂

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

    1. 输入:n = 16
    2. 输出:true
    3. 输入:n = 5
    4. 输出:false
    5. 输入:n = 1
    6. 输出:true

    方法一:递归

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

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

    方法二:递归(优化版)

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

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

    方法三:暴力循环

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

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

    方法四:暴力循环

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

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

    总结

    硬是打了31个1和0!

  • 相关阅读:
    8张图解java
    OpenGL 饱和度调节
    【react】点击空白处隐藏
    04-vue-cli-启动配置和静态资源配置
    基于记忆与模型协同过滤的电影推荐系统研究与实践(文末送书)
    常见首屏优化
    es6中proxy如何使用
    图像处理之图像质量评价指标PSNR(峰值信噪比)
    openGauss数据库客户端连接工具之Datastudio安装
    音视频 ffplay命令播放媒体
  • 原文地址:https://blog.csdn.net/m0_61661179/article/details/128213603