Leetcode 393. UTF-8 编码验证

1.题目基本信息

1.1.题目描述

给定一个表示数据的整数数组 data ,返回它是否为有效的 UTF-8 编码。

UTF-8 中的一个字符可能的长度为 1 到 4 字节,遵循以下的规则:

  1. 对于 1 字节 的字符,字节的第一位设为 0 ,后面 7 位为这个符号的 unicode 码。

  2. 对于 n 字节 的字符 (n > 1),第一个字节的前 n 位都设为1,第 n+1 位设为 0 ,后面字节的前两位一律设为 10 。剩下的没有提及的二进制位,全部为这个符号的 unicode 码。

注意:输入是整数数组。只有每个整数的 最低 8 个有效位 用来存储数据。这意味着每个整数只表示 1 字节的数据。

1.2.题目地址

https://leetcode.cn/problems/utf-8-validation/description/

2.解题方法

2.1.解题思路

二进制运算+遍历

时间复杂度:O(n)

2.2.解题步骤

第一步,找到data[i]开头连续1的个数,确定当前字符串的位数digit

第二步,连续1位0个,表示为单字符;开头连续1的一个的不能作为单字符,为非法子串

第三步,验证data中连续的digit位是否是合法的utf-8字符

第四步,更新i指针,开始验证下一个字符

3.解题代码

python代码

python 复制代码
class Solution:
    def validUtf8(self, data: List[int]) -> bool:
        n = len(data)
        i = 0
        while i < n:
            # 第一步,找到data[i]开头连续1的个数,确定当前字符串的位数digit
            j = 0
            while j < 5 and (data[i] >> (7 - j)) & 1 == 1:
                j += 1
            if j > 4:
                return False
            # 第二步,连续1位0个,表示为单字符;开头连续1的一个的不能作为单字符,为非法子串
            if j == 0:
                i += 1
                continue
            if j == 1:
                return False
            # 第三步,验证data中连续的digit位是否是合法的utf-8字符
            for k in range(j - 1):
                if i + k + 1 >= n:
                    return False
                val = data[i + k + 1]
                if (val >> 7) & 1 != 1 or (val >> 6) & 1 != 0:
                    return False
            # 第四步,更新i指针,开始验证下一个字符
            i += j
        return True

4.执行结果

相关推荐
16_one9 分钟前
autoDL安装Open-WebUi+Rag本地知识库问答+Function Calling
人工智能·后端·算法
散峰而望1 小时前
C++数组(三)(算法竞赛)
开发语言·c++·算法·github
q***95221 小时前
SpringMVC 请求参数接收
前端·javascript·算法
初级炼丹师(爱说实话版)2 小时前
多进程与多线程的优缺点及适用场景总结
算法
hetao17338372 小时前
2025-11-25~26 hetao1733837的刷题记录
c++·算法
历程里程碑2 小时前
各种排序法大全
c语言·数据结构·笔记·算法·排序算法
少许极端2 小时前
算法奇妙屋(十四)-简单多状态dp问题
算法·动态规划·图解算法·简单多状态dp·打家劫舍问题·买卖股票问题全解
爱学测试的雨果2 小时前
收藏!软件测试面试题
开发语言·面试·职场和发展
川Princess3 小时前
【面试经验】梅赛德斯奔驰X-Seed AI Systems - Autonomous Driving Agent Efficiency二面
面试·职场和发展
2301_823438023 小时前
解析论文《复杂海上救援环境中无人机群的双阶段协作路径规划与任务分配》
人工智能·算法·无人机