码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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!

  • 相关阅读:
    C# 用VS原生CheckBox控件制作漂亮的开关
    Windows 10驱动开发入门(四):USB下的过滤器驱动
    【c++】模拟实现优先级队列(priority_queue)
    华测监测预警系统 2.2 任意文件读取漏洞复现 [附POC]
    PHP幸运抽奖系统带后台源码
    vue父组件向子组件传值的方法
    MongoDB副本集集群原理以及维护配置
    编译器技术的演进与变革
    vue子组件向父组件传值
    shell 函数
  • 原文地址:https://blog.csdn.net/m0_61661179/article/details/128213603
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号