leetcode 190. 颠倒二进制位(c++)
发布时间:2020-12-16 10:47:15 所属栏目:百科 来源:网络整理
导读:颠倒给定的 32 位无符号整数的二进制位。 ? 示例 1: 输入: 00000010100101000001111010011100 输出: 00111001011110000010100101000000 解释: 输入的二进制串 00000010100101000001111010011100 表示无符号整数 43261596, 因此返回 964176192,其二进制表
颠倒给定的 32 位无符号整数的二进制位。 ? 示例 1: 输入: 00000010100101000001111010011100 输入:22222222222222222222222222222201 class Solution { public: uint32_t reverseBits(uint32_t n) { uint32_t res = 0; for (int i = 0; i < 32; ++i) { if (n & 1 == 1) { // 最后一位为1 res = (res << 1) + 1; } else { res = res << 1; } n = n >> 1; } return res; } }; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |