393. UTF-8 编码验证

393. UTF-8 编码验证

 注意:题目中说的是每个字节的长度,并不是字节的个数

class Solution {
    public boolean validUtf8(int[] data) {
        int n = data.length;
        int count = 0;
        for (int i = 0; i < n; i++) {
            String s = Integer.toBinaryString(data[i]);//将十进制转换为二进制
            if (s.length() > 8) {//大于长度8则截取最后8位,小于长度8则前面用0补足
                s.substring(s.length() - 8, s.length());
            } else if (s.length() < 8) {
                s = "00000000".substring(0, 8 - s.length()) + s;
            }
            if (count == 0) {//用count计数非单字节字符的数量
                for (int j = 0; j < s.length(); j++) {//记录非单字节首字符中前面有多少个0,则后面需要多少个10开头的字节
                    if (s.charAt(j) == '0')
                        break;
                    count++;
                }
                if (count == 0)//count=0,表示单字节字符,直接跳到下一个字节
                    continue;
                if (count < 2 || count > 4) return false;
            } else {
                if (!(s.charAt(0) == '1' && s.charAt(1) == '0'))
                    return false;
            }
            count--;
        }
            return count == 0;
    }
}

上一篇:第一天 删除无效括号


下一篇:Rstudio( bioconductor)下载太慢,用国内镜像