| |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| -> 数据结构与算法 -> LeetCode:2的幂 -> 正文阅读 |
|
|
[数据结构与算法]LeetCode:2的幂 |
2的幂这道题出自LeetCode,题目如下: 给你一个整数 如果存在一个整数 示例 1:
示例 2:
示例 3:
示例 4:
示例 5:
这道题有3种比较trick的解法。首先,如果一个整数它是2的幂次方,那么它的二进制表示必然为:
第二种解法是计算n的最低二进制位为1的数是否与n相等。如果相等,说明n只有一个二进制位为1。计算n的最低二进制位为1的数的方法是去计算n & (-n)的值:
最后还有一种比较取巧的做法,就是我们已知最大的2的幂的值为 2 30 = 1073741824 2^{30}=1073741824 230=1073741824,那么只要判断n是否为其约数即可:
|
|
|
|
|
| 上一篇文章 下一篇文章 查看所有文章 |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| 360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年12日历 | -2025/12/2 11:48:59- |
|
| 网站联系: qq:121756557 email:121756557@qq.com IT数码 |