190. Reverse Bits

题目

Reverse bits of a given 32 bits unsigned integer.

For example, given input 43261596 (represented in binary as 00000010100101000001111010011100), return 964176192 (represented in binary as 00111001011110000010100101000000).

挺简单的 直接上代码

#coding:utf-8

class Solution:
    # @param n, an integer
    # @return an integer
    def reverseBits(self, n):
        keep = ""
        while(n != 0):
            if(n % 2 == 1):
                keep += "1"
            else:
                keep += "0"
            n = n / 2

        # keep = keep[::-1]

        temp = ""
        i = 32 - len(keep)
        while i >0 :
            temp += "0"
            i -= 1
        keep =  keep + temp

        orgin = 0
        length = len(keep) -1

        for i in keep:
            if i == "1":
                orgin += pow(2,length)
            length -= 1

        return orgin

if __name__ == "__main__":
    test = Solution()
    print test.reverseBits(43261596)

你可能感兴趣的:(190. Reverse Bits)