2025.11.08 力扣每日一题

1611.使整数变为0的最少操作整数

cpp 复制代码
class Solution {
public:
    int minimumOneBitOperations(int n) {
        if (n == 0) {
            return 0;
        }
        int x = 31 - __builtin_clz(n);
        return (1 << (x + 1)) - 1 - minimumOneBitOperations(n - (1 << x));//抵消反向操作
    }
};
方法二:迭代

思路与算法

我们可以将方法一的递归改成迭代。这样的好处在于:

  • 我们不需要显式求解出 n 的位数 x;
  • 省去了递归需要的栈空间。

代码

cpp 复制代码
class Solution {
public:
    int minimumOneBitOperations(int n) {
        int ans = 0;       // 存储最终的最少操作次数
        int sign = 1;      // 符号位,控制当前位的贡献是加还是减,初始为正
        // 遍历二进制的第29位到第0位(覆盖了32位整数中可能出现1的大部分位置)
        for (int i = 29; i >= 0; i--) {
            // 检查n的第i位是否为1(1<<i是第i位为1的掩码)
            if (n & (1 << i)) {
                // 若第i位为1,累加其贡献值:sign * (2^(i+1) - 1)
                ans += sign * ((1 << (i + 1)) - 1);
                // 翻转符号(下一个1的贡献会是相反的符号)
                sign = -sign;
            }
        }
        return ans;
    }
};

按照二进制位从高到低的顺序,根据每个 1 的位置计算其基准操作次数,再通过符号交替体现位之间的抵消关系,最终累加得到总操作次数。

相关推荐
bIo7lyA8v4 分钟前
算法复杂度评估的实验统计方法与可视化的技术8
算法
李老师讲编程25 分钟前
中国电子学会图形化2020.12月Scratch三级考级题
算法·scratch·信息学奥赛·图形化编程·scratch素材
退休倒计时1 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript
旖-旎1 小时前
FloodFill(图像渲染)(1)
c++·算法·深度优先·力扣
戴西软件1 小时前
戴西 DLM 许可授权管理系统:破解无网络环境下工业软件授权难题,助力制造企业降本增效
网络·人工智能·python·深度学习·程序人生·算法·制造
2601_961875241 小时前
法考资料2026|全套|资料已整理
数据结构·算法·链表·贪心算法·eclipse·线性回归·动态规划
无限码力1 小时前
美团研发岗 4月18号笔试真题 - 坐标
算法·美团笔试真题·美团笔试题·美团研发岗笔试题·美团研发岗4月18号真题
有点。2 小时前
C++倍增法(练习题)
c++·算法
智者知已应修善业3 小时前
【51单片机8位数码管同时倒计时从9999】2024-1-25
c++·经验分享·笔记·算法·51单片机