zoukankan      html  css  js  c++  java
  • Leetcode476.Number Complement数字的补数

    给定一个正整数,输出它的补数。补数是对该数的二进制表示取反。

    注意:

    1. 给定的整数保证在32位带符号整数的范围内。
    2. 你可以假定二进制数不包含前导零位。

    示例 1:

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

    示例 2:

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

    class Solution {
    public:
        int findComplement(int num) {
            int n = 0;
            int temp = num;
            while(temp)
            {
                temp /= 2;
                n++;
            }
            temp = 1;
            while(n--)
            {
                num = num ^ temp;
                temp = temp << 1;
            }
            return num;
        }
    };
  • 相关阅读:
    mysql 行号
    java 异常链
    springsecurity密码加密
    java 四舍五入
    ArrayList的使用及原理
    java 匿名内部类
    java 克隆
    logback的配置
    信号量 Semaphore
    障碍器 CyclicBarrier
  • 原文地址:https://www.cnblogs.com/lMonster81/p/10434081.html
Copyright © 2011-2022 走看看