有两种特殊字符。第一种字符可以用一比特0来表示。第二种字符可以用两比特(10 或 11)来表示。

现给一个由若干比特组成的字符串。问最后一个字符是否必定为一个一比特字符。给定的字符串总是由0结束。

示例 1:

输入: 
bits = [1, 0, 0]
输出: True
解释: 
唯一的编码方式是一个两比特字符和一个一比特字符。所以最后一个字符是一比特字符。

示例 2:

输入: 
bits = [1, 1, 1, 0]
输出: False
解释: 
唯一的编码方式是两比特字符和两比特字符。所以最后一个字符不是一比特字符。

注意:

  • 1 <= len(bits) <= 1000.
  • bits[i] 总是0 或 1.
class Solution(object):
    def isOneBitCharacter(self, bits):
        """
        :type bits: List[int]
        :rtype: bool
        """
        # 遇1进二直接跳到下一个数,判断最后是否指向最后一个元素
        i = 0
        while i < len(bits):
            if i == len(bits)-1:
                return True
            elif bits[i] == 1:
                i += 2
            else:
                i += 1
        return False
View Code

相关文章:

  • 2021-10-03
  • 2021-12-09
  • 2022-12-23
  • 2021-10-03
  • 2021-10-03
  • 2021-04-10
  • 2021-05-15
猜你喜欢
  • 2018-08-31
  • 2021-09-13
  • 2021-12-10
  • 2022-12-23
  • 2022-02-10
  • 2021-12-25
  • 2021-10-09
相关资源
相似解决方案