力扣刷题--476. 数字的补数【简单】

题目描述

对整数的二进制表示取反(0 变 1 ,1 变 0)后,再转换为十进制表示,可以得到这个整数的补数。

例如,整数 5 的二进制表示是 "101" ,取反后得到 "010" ,再转回十进制表示得到补数 2 。

给你一个整数 num ,输出它的补数。

示例 1:

输入:num = 5

输出:2

解释:5 的二进制表示为 101(没有前导零位),其补数为 010。所以你需要输出 2 。

示例 2:

输入:num = 1

输出:0

解释:1 的二进制表示为 1(没有前导零位),其补数为 0。所以你需要输出 0 。

提示:

1 <= num < 231

算法分析

将其转为二进制数的字符串处理,按题意模拟

完整代码

cpp 复制代码
class Solution {
public:
    int findComplement(int num) {
        string ans;
        while(num)
        {
            ans=to_string(num%2)+ans;    
            num/=2;    
        }
        int sum=0;    
        for(int i=0;i<ans.size();i++)    
        {
            if(ans[i]=='1')    
                ans[i]='0';    
            else    
                ans[i]='1';    
        }
        for(int i=ans.size()-1;i>=0;i--)    
        {
            if(ans[i]=='1')    
                sum+=pow(2,ans.size()-i-1);    
        }
        return sum;    
    }
};

相关推荐
2401_891482173 小时前
多平台UI框架C++开发
开发语言·c++·算法
88号技师3 小时前
2026年3月中科院一区SCI-贝塞尔曲线优化算法Bezier curve-based optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
t198751283 小时前
三维点云最小二乘拟合MATLAB程序
开发语言·算法·matlab
无敌昊哥战神3 小时前
【LeetCode 257】二叉树的所有路径(回溯法/深度优先遍历)- Python/C/C++详细题解
c语言·c++·python·leetcode·深度优先
㓗冽3 小时前
8皇后·改-进阶题16
数据结构
x_xbx4 小时前
LeetCode:148. 排序链表
算法·leetcode·链表
Darkwanderor4 小时前
三分算法的简单应用
c++·算法·三分法·三分算法
2401_831920744 小时前
分布式系统安全通信
开发语言·c++·算法
WolfGang0073215 小时前
代码随想录算法训练营 Day17 | 二叉树 part07
算法
温九味闻醉5 小时前
关于腾讯广告算法大赛2025项目分析1 - dataset.py
人工智能·算法·机器学习