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)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容