LeetCode—Python—476—数字的补数

  • Post author:
  • Post category:python


这个题是有点东西的,虽然Python的还是一如既往的方便,但相对的可以钻空子的地方少了很多。代码思路其实比较普通,写的也没有太精简,求一个思路安稳吧也就是,如果需要

代码出现!(我以前是不是用过这个…..最近发现每次这样好中二啊)

class Solution:
    def findComplement(self, num):
        """
        :type num: int
        :rtype: int
        """
        temp = 1
        s = str(bin(num))
        length = len(s)-2
        while length:
            length -= 1
            num = num ^ temp
            temp *= 2
        return num


基本思路:

记临时为一个整的二进制数(我也不知道应该怎么叫..理解就好…),也就是2的N次幂,每次循环对num进行一次^位运算,即进行一次对位异或,关于循环的终止条件就是跑完原num的二进制位数


坑:

不要尝试取反的位运算符,虽然这个题给定的都是正整数,但是在算的时候确实是以补码为准的按位取反,换句话说,取反位运算后的结果都是 -(x+1)

这里说一下bin()这个函数,转二进制的时候,会在前端生成0B或者-0b的两位(三位)说明符,所以算长度的时候需要减一下

其他…. emmmmm …零坑任踏吧


一江浊水向东流



版权声明:本文为v0neath原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。