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

相关推荐
穿条秋裤到处跑几秒前
每日一道leetcode(2026.04.07):模拟行走机器人 II
leetcode·机器人
sheeta19984 分钟前
LeetCode 每日一题笔记 日期:2026.04.07 题目:2069.模拟行走机器人二
笔记·leetcode·机器人
im_AMBER4 分钟前
Leetcode 153 课程表 | 腐烂的橘子
开发语言·算法·leetcode·深度优先·图搜索
paeamecium6 分钟前
【PAT甲级真题】- Reversing Linked List (25)
数据结构·c++·算法·pat
田梓燊8 分钟前
leetcode 73
算法·leetcode·职场和发展
ZPC821015 分钟前
相机接入ROS2 流程及问题排查
人工智能·算法·机器人
2501_9403152615 分钟前
【无标题】两个相同字符串中不同字符的个数
算法·哈希算法·散列表
6Hzlia20 分钟前
【Hot 100 刷题计划】 LeetCode 54. 螺旋矩阵 | C++ 模拟法题解
c++·leetcode·矩阵
算法鑫探25 分钟前
显示器插座最短连线算法(蓝桥杯十六届C组编程题第二题)
c语言·数据结构·算法·排序算法·新人首发
akarinnnn30 分钟前
【DAY15】:深⼊理解指针(6)
算法