LeetCode 717. 1比特与2比特字符

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/zx2015216856/article/details/81878030

有两种特殊字符。第一种字符可以用一比特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一定与一个1或者0配对,0可以单独存在,所以一串字符只有一种可能性;

           遍历数组,遇到1,就加2;遇到0,就加一;如果能遍历到最后一位,最后一位一定为1比特字符;

    public boolean isOneBitCharacter(int[] bits) {
        for(int i = 0; i < bits.length; ) {
        	if(bits[i] == 1) {
        		i = i + 2;
        	}else {
        		if(i == bits.length - 1)
        			return true;
        		i ++;
        	}
        }
		return false;
    }

猜你喜欢

转载自blog.csdn.net/zx2015216856/article/details/81878030