1-bit and 2-bit Characters Problem & Solution

We have two special characters:

  • The first character can be represented by one bit 0.
  • The second character can be represented by two bits (10 or 11).

Given a binary array bits that ends with 0, return true if the last character must be a one-bit character.

See the 1-bit and 2-bit characters problem on LeetCode.

C++ Solution

#pragma GCC optimize("Ofast")
#pragma GCC optimization("unroll-loops")

static const int _=[](){ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);return 0;}();

class Solution {
public:
  bool isOneBitCharacter(vector<int>& bits) {
    for (int i = 0; i < bits.size(); ++i) {

      // Skips two positions if `bits[i]` is 1 because the next position can't be a one-bit character.
      if (bits[i] == 1) {
        i += 1;
      } else if (i == bits.size() - 1 && bits[i] == 0) {
        return true;
      }
    }

    return false;
  }
};

Start Here

Many paths, there are. Follow yours, you must.