力扣刷题--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;    
    }
};

相关推荐
Felven1 分钟前
B. MEXor Mixup
算法
阿崽meitoufa12 分钟前
JVM虚拟机:垃圾收集算法
java·jvm·算法
练习时长一年16 分钟前
LeetCode热题100(分割等和子集)
算法·leetcode·职场和发展
52Hz11821 分钟前
力扣148.排序链表
leetcode
七号驿栈27 分钟前
07_汽车信息安全算法在线验证工具(测试报告)
算法
啦哈拉哈43 分钟前
【Python】知识点零碎学习4
python·学习·算法
iAkuya1 小时前
(leetcode)力扣100 46二叉树展开为链表(递归||迭代||右子树的前置节点)
windows·leetcode·链表
爱喝可乐的老王1 小时前
线性回归模型案例:广告投放效果预测
算法·回归·线性回归
程序员-King.2 小时前
day151—双端队列—找树左下角的值(LeetCode-513)
算法·leetcode·二叉树·双端队列·队列
苦藤新鸡2 小时前
15 .数组右移动k个单位
算法·leetcode·动态规划·力扣