logseq_notes/pages/OJ notes/pages/Leetcode Reverse-Bits.md
2023-06-14 14:27:22 +08:00

2.4 KiB

Leetcode Reverse-Bits

2022-07-22 15:15

Algorithms:

#algorithm #bit_manipulation

Data structures:

#DS #bitset

Difficulty:

#coding_problems #difficulty_easy

Additional tags:

#leetcode

Revisions:

N/A

Problem

Reverse bits of a given 32 bits unsigned integer.

Examples

Example 1:

Input: n = 00000010100101000001111010011100 Output: 964176192 (00111001011110000010100101000000) Explanation: The input binary string 00000010100101000001111010011100 represents the unsigned integer 43261596, so return 964176192 which its binary representation is 00111001011110000010100101000000.

Example 2:

Input: n = 11111111111111111111111111111101 Output: 3221225471 (10111111111111111111111111111111) Explanation: The input binary string 11111111111111111111111111111101 represents the unsigned integer 4294967293, so return 3221225471 which its binary representation is 10111111111111111111111111111111.

Constraints

  • The input must be a binary string of length 32

Thoughts

id:: 641ff3d4-afbc-4d0e-82d5-8adb2ff0ad93

[!summary] This is a #bit_manipulation problem.

There are two methods:

  • swapping bits inside the bitset
  • shifting

Method 1: Swapping

This is the most simple and intuitive one, all you have to do is swap the first and last numbers, and continue like that.

  • Method 2: Shifting

    The bitset has operations like this << >>, which can be used to shift, and reverse the array.

    The operation is already documented in the link above. ((641ff3d4-afbc-4d0e-82d5-8adb2ff0ad93))

Solution

Method 1:

class Solution {
public:
uint32_t reverseBits(uint32_t n) {
  // swap bits inside the function
  bitset<32> nb(n);
  bool tmp;
  int l = 0, r = 31;

  while (l < r) {
    tmp = nb[l];
    nb[l] = nb[r];
    nb[r] = tmp;
    l++;
    r--;
  }

  return nb.to_ulong();
}
};

Shifting:

==#TODO solve it using shifting==