有两种特殊字符。第一种字符可以用一比特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
.
思路:
这题应该反向推导,
1)倒数第一位是0;
2)倒数第二位如果是0 不用管其他的,肯定为"True",如果是1需要看第三位;
3)倒数第三位如果是0肯定为False,如果是1待定,继续往下分析
。。。。
找出规律之后就是如何实现了,简单来说就是我需要确定倒数第二个0的反向索引下标。如果是偶数数肯定为False,如果是奇数,答案为True
class Solution(object):
def isOneBitCharacter(self, bits):
"""
:type bits: List[int]
:rtype: bool
"""
bits_reverse = bits[::-1]
bits_reverse.append(0)
id1 = [i for i,x in enumerate(bits_reverse) if x==0]
if id1[1] % 2 == 0:
return False
else:
return True