• 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!

  • 相关阅读:
    第2章 Spring Boot实践,开发社区登录模块(下)
    有效供应链管理的八大绩效分析指标(上)
    【学习笔记】ARC146/AGC020/
    桂林理工大学计算机考研资料汇总
    二、vue基础入门
    LinkedHashMap
    9. SAP ABAP OData 服务如何支持删除(Delete)操作
    0动态规划+二分查找中等 LeetCode2008. 出租车的最大盈利
    Go语言的[GPM模型]
    WireShark抓包工具的安装
  • 原文地址:https://blog.csdn.net/m0_61661179/article/details/128213603