717.1比特与2比特字符
Posted kloseer
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了717.1比特与2比特字符相关的知识,希望对你有一定的参考价值。
题目
有两种特殊字符。第一种字符可以用一比特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 {
public:
bool isOneBitCharacter(vector<int>& bits) {
bool result;
int i = 0;
while(i < bits.size())
{
if(bits[i] == 1)
{
i = i+2;
result = false;
}
else
{
i++;
result = true;
}
}
return result;
}
};
笔记:遇到1,i+2跳过 ,因为10或者11都属于2比特,遇到0 ,i++,循坏到i>.bits.size()。
以上是关于717.1比特与2比特字符的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode717. 1比特与2比特字符(python3)
LeetCode 717. 1 比特与 2 比特字符 / 838. 推多米诺 / 1994. 好子集的数目(状态压缩动态规划)