LeetCode 3370.仅含置位位的最小整数

题目

给你一个正整数 n

返回 大于等于 n 且二进制表示仅包含 置位 位的 最小 整数 x 。(全是1)

置位 位指的是二进制表示中值为 1 的位。

思路:计算 n 的二进制长度 m,返回长为 m 的全为 1 的二进制数,也就是2^m−1

代码

java 复制代码
class Solution {
    public int smallestNumber(int n) {
        int m = 32 - Integer.numberOfLeadingZeros(n);
        // 1 左移 m 位,相当于 1 * 2^m
        return (1 << m) - 1;
    }
}

性能

时间复杂度:O(1)

空间复杂度:O(1)

相关推荐
suuijbd几秒前
个人总结八股文之-基础篇(持续更新)
算法
2401_881244402 分钟前
斐波那契数列------矩阵幂法
线性代数·算法·矩阵
机器学习与统计学24 分钟前
阿里牛逼,又开源两个遥遥领先的模型(向量化、重排),知识库要翻天地覆了
算法
小河豚oO28 分钟前
LeetCode刷题---贪心算法---944
算法·leetcode·贪心算法
【杨(_> <_)】30 分钟前
信号处理分析工具——时频分析(一)
算法·matlab·信号处理
还不起来学习?34 分钟前
常见算法题目5 -常见的排序算法
java·算法·排序算法
Once_day1 小时前
代码训练LeetCode(23)随机访问元素
算法·leetcode
小河豚oO1 小时前
LeetCode 热题 100 - 哈希 - 128
算法·leetcode·哈希算法
客卿1231 小时前
力扣100题之128. 最长连续序列
算法·leetcode·哈希算法
T1an-11 小时前
【力扣链表篇】206.反转链表
算法·leetcode·链表