首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

十进制整数的反码(位运算)

题目 每个非负整数 N 都有其二进制表示。例如, 5 可以被表示为二进制 “101”,11 可以用二进制 “1011” 表示,依此类推。注意,除 N = 0 外,任何二进制表示中都不含前导零。...二进制的反码表示是将每个 1 改为 0 且每个 0 变为 1。例如,二进制数 “101” 的二进制反码为 “010”。 给定十进制数 N,返回其二进制表示的反码所对应的十进制整数。 2....解题 求出二进制的非零位数,再用32减去它,左移这么多位(高位没了),取反(结果+111…),再右移这么多位(末位的111…去掉了) class Solution { public: int bitwiseComplement...{ bits--; Nc >>= 1; } return ~(N > bits; } }; 一个数和它的反码之和等于

41210
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    字符串转换整数 (atoi)

    字符串转换整数 请你来实现一个 atoi 函数,使其能将字符串转换成整数。 字符串包含的字符包括:数字、大小写字母、+、-、空格。...字符串能够转成整数必须满足如下要求: 字符串第一个字符必须是数字或者 +、- 符号之一; +、- 或者数字之间必须是连续的才能转成整数; 其他情况下无法进行有效转换的时候返回 0; 转换后的数字必须在...因此无法执行有效的转换。 示例 5: 输入: "-91283472332" 输出: -2147483648 解释: 数字 "-91283472332" 超过 32 位有符号整数范围。...思路: 不用正则,不用 parseInt() 函数; 先把字符串头尾去空格,返回一个新的字符串; 如果字符串第一个字符是除 + - 之外的字符,则返回 0; 此时第一个字符一定是 +、- 或者数字之一。...从第二个字符开始遍历,如果是空格或者非数字则直接跳出循环,并且记住此时的遍历位置,通过字符串截取就能获得能够转换成整数的字符串; 再把字符串转成数字后与 32 位有符号位整数范围相比,返回对应的数字;

    1.7K30

    leetcode - 字符串转换整数 (atoi)

    题意 请你来实现一个 atoi 函数,使其能将字符串转换成整数。 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。...假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成一个整数。该字符串在有效的整数部分之后也可能会存在多余的字符,那么这些字符可以被忽略,它们对函数不应该造成影响。...假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换,即无法进行有效转换。 在任何情况下,若函数不能进行有效的转换时,请返回 0 。...注意: 本题中的空白字符只包括空格字符 ' '。 假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−2^31, 2^31 − 1]。...因此无法执行有效的转换。 示例 5: 输入: "-91283472332" 输出: -2147483648 解释: 数字 "-91283472332" 超过 32 位有符号整数范围。

    71820

    python实现字符串转换整数

    实现一个函数,使其能将字符串转换成整数。 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。...该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响。...注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换。 在任何情况下,若函数不能进行有效的转换时,请返回 0。...说明: ​ 假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231,  231 − 1]。...因此无法执行有效的转换。 示例 5: 输入: "-91283472332" 输出: -2147483648 解释: 数字 "-91283472332" 超过 32 位有符号整数范围。

    1.3K30

    LeetCode【8】-- 字符串转换整数

    32 位有符号整数(类似 C/C++ 中的 atoi 函数)。...读入下一个字符,直到到达下一个非数字字符或到达输入的结尾。字符串的其余部分将被忽略。 将前面步骤读入的这些数字转换为整数(即,"123" -> 123, "0032" -> 32)。...如果没有读入数字,则整数为 0 。必要时更改符号(从步骤 2 开始)。 如果整数数超过 32 位有符号整数范围 [−231, 231 − 1] ,需要截断这个整数,使其保持在这个范围内。...除前导空格或数字后的其余字符串外,请勿忽略 任何其他字符。 示例 1: 输入:s = "42" 输出:42 解释:加粗的字符串为已经读入的字符,插入符号是当前读取的字符。...3.接下来的字符必须是数字,遇到其他字符会直接结束 4.需要考虑溢出的问题 在将字符串转换成数字的时候,用下面这句核心代码: sum = sum * 10 + (str.charAt(i) - '0')

    64910

    8 字符串转换整数 (atoi)

    01 题目信息 题目地址: https://leetcode-cn.com/problems/string-to-integer-atoi/ 请你来实现一个 atoi 函数,使其能将字符串转换成整数。...注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换,即无法进行有效转换。...假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231, 231 − 1]。...因此无法执行有效的转换。 示例 5: 输入: "-91283472332"输出: -2147483648解释: 数字 "-91283472332" 超过 32 位有符号整数范围。...04 有限状态自动机 正则表达的所匹配的所有字符串构成都可以用有限自动机识别,其实上面解法的每个过程判定就是一个有限自动机的每个状态。从去除空格阶段到取符号阶段到数字阶段到结束。

    65020

    C语言关于进制转换,补码, 整数的位操作

    一、进制转换  //关于进制转换,从网上找了几张经典图片,便于后面查询 1、二进制转十进制、八进制转十进制、十六进制转十进制 2、十进制转二进制, 十进制转八进制,十进制转十六进制 3、二进制转八进制,...,可以让最高位符号位都能参与计算; 正数的补码和原码一样,负数的补码是其反码+1    整数在计算机中以补码的方式存储,不管是正数还是负数。...&、异或^、位移的举例应用 /* 题目1、输入一个整数num, 打印该整数num的二进制 该题运用到位移、按位且& */ int num =9; for (...可以多种方式实现,这里我们使用按位&来实现, 任何位&1都为该位,即0&1=0, 1&1=1 分析:整数二进制最后一位为1的是奇数,为0的是偶数 0001 1...a和b, 交换两个整数的值 可以使用按位异或来处理:任何数num异或另外一个数num2两次都为该数num */ int a = 10, b = 8; //第一种方式,

    5.1K60

    LeetCode 字符串转换整数 (atoi)(字符串)

    题目 请你来实现一个 atoi 函数,使其能将字符串转换成整数。 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。...假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成一个整数。 该字符串在有效的整数部分之后也可能会存在多余的字符,那么这些字符可以被忽略,它们对函数不应该造成影响。...注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换,即无法进行有效转换。...假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231,  231 − 1]。...因此无法执行有效的转换。

    37720

    LeetCode-8 字符串转换整数

    字符串转换整数 > 难度:中等 > 分类:字符串 > 解决方案:字符串遍历 今天我们学习第8题字符串转换整数,这是一个字符串的中等题,像这样字符串的题目经常作为面试题来考察面试者算法能力和写代码能力...下面我们看看这道题的题目描述。 题目描述 请你来实现一个 atoi函数,使其能将字符串转换成整数。...注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换。 在任何情况下,若函数不能进行有效的转换时,请返回 0。...因此无法执行有效的转换。 示例5: 输入: "-91283472332"输出: -2147483648解释: 数字 "-91283472332" 超过 32 位有符号整数范围。...分析 这个字符串转换整数的题比较常规,题目和示例中已经详细说明了转换过程及转换的情况,具体归纳如下: 如果字符串开头为空格,则跳过所有的空格字符,直到寻找到第一个非空格的字符为止,如果全部都是空格

    77920

    LeetCode - #8 字符串转换整数 (atoi)

    描述 实现一个 func myAtoi(_ str: String) -> Int 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。...读入下一个字符,直到到达下一个非数字字符或到达输入的结尾。字符串的其余部分将被忽略。 将前面步骤读入的这些数字转换为整数(即,"123" -> 123, "0032" -> 32)。...如果没有读入数字,则整数为 0 。必要时更改符号(从步骤 2 开始)。 如果整数数超过 32 位有符号整数范围 [−2^31, 2^31 − 1] ,需要截断这个整数,使其保持在这个范围内。...注意: 本题中的空白字符只包括空格字符 ' ' 。 除前导空格或数字后的其余字符串外,请勿忽略 任何其他字符。 2....示例 示例 1 输入:str = "42" 输出:42 解释:加粗的字符串为已经读入的字符,插入符号是当前读取的字符。

    44930

    【LeetCode08】字符串转换整数

    请你来实现一个 atoi 函数,使其能将字符串转换成整数。 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。...该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响。...注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换。 在任何情况下,若函数不能进行有效的转换时,请返回 0。...说明: 假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231, 231 − 1]。...因此无法执行有效的转换。 示例 5: 输入: "-91283472332"输出: -2147483648解释: 数字 "-91283472332" 超过 32 位有符号整数范围。

    67110
    领券