java?LeetCode普通字符串模擬題解示例
題目描述
這是 LeetCode 上的 393. UTF-8 編碼驗證 ,難度為 中等。
Tag : 「模擬」
給定一個表示數(shù)據(jù)的整數(shù)數(shù)組 data
,返回它是否為有效的 UTF−8 編碼。
UTF-8
中的一個字符可能的長度為 1 到 4 字節(jié),遵循以下的規(guī)則:
- 對于 1字節(jié) 的字符,字節(jié)的第一位設(shè)為 0,后面 7 位為這個符號的
unicode
碼。 - 對于 n 字節(jié) 的字符 (n>1),第一個字節(jié)的前 n 位都設(shè)為 1,第 n+1 位設(shè)為 0 ,后面字節(jié)的前兩位一律設(shè)為 10。剩下的沒有提及的二進制位,全部為這個符號的
unicode
碼。
這是 UTF-8 編碼的工作方式:
Char. number range | UTF-8 octet sequence (hexadecimal) | (binary) --------------------+--------------------------------------------- 0000 0000-0000 007F | 0xxxxxxx 0000 0080-0000 07FF | 110xxxxx 10xxxxxx 0000 0800-0000 FFFF | 1110xxxx 10xxxxxx 10xxxxxx 0001 0000-0010 FFFF | 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
注意:輸入是整數(shù)數(shù)組。只有每個整數(shù)的 最低 8 個有效位 用來存儲數(shù)據(jù)。這意味著每個整數(shù)只表示 1 字節(jié)的數(shù)據(jù)。
示例 1:
輸入:data = [197,130,1]
輸出:true
解釋:數(shù)據(jù)表示字節(jié)序列:11000101 10000010 00000001。
這是有效的 utf-8 編碼,為一個 2 字節(jié)字符,跟著一個 1 字節(jié)字符。
示例 2:
輸入:data = [235,140,4]
輸出:false
解釋:數(shù)據(jù)表示 8 位的序列: 11101011 10001100 00000100.
前 3 位都是 1 ,第 4 位為 0 表示它是一個 3 字節(jié)字符。
下一個字節(jié)是開頭為 10 的延續(xù)字節(jié),這是正確的。
但第二個延續(xù)字節(jié)不以 10 開頭,所以是不符合規(guī)則的。
提示:
模擬
根據(jù)題意進行模擬即可。
如果上述過程滿足要求,跳到下一個檢查點進行檢查,整個 data
都沒有沖突則返回 True
。
代碼:
class Solution { public boolean validUtf8(int[] data) { int n = data.length; for (int i = 0; i < n; ) { int t = data[i], j = 7; while (j >= 0 && (((t >> j) & 1) == 1)) j--; int cnt = 7 - j; if (cnt == 1 || cnt > 4) return false; if (i + cnt - 1 >= n) return false; for (int k = i + 1; k < i + cnt; k++) { if ((((data[k] >> 7) & 1) == 1) && (((data[k] >> 6) & 1) == 0)) continue; return false; } i += cnt == 0 ? 1 : cnt; } return true; } }
- 時間復(fù)雜度:O(n)
- 空間復(fù)雜度:O(1)
最后
這是我們「刷穿 LeetCode」系列文章的第 No.393
篇,系列開始于 2021/01/01,截止于起始日 LeetCode 上共有 1916 道題目,部分是有鎖題,我們將先把所有不帶鎖的題目刷完。
在這個系列文章里面,除了講解解題思路以外,還會盡可能給出最為簡潔的代碼。如果涉及通解還會相應(yīng)的代碼模板。
為了方便各位同學(xué)能夠電腦上進行調(diào)試和提交代碼,我建立了相關(guān)的倉庫:github.com/SharingSour… 。
以上就是java LeetCode普通字符串模擬題解示例的詳細內(nèi)容,更多關(guān)于java LeetCode普通字符串的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java報錯:FileNotFoundException的解決方案
在Java編程中,FileNotFoundException 是一種常見的受檢異常,通常發(fā)生在試圖打開一個不存在的文件或文件路徑錯誤時,本文將詳細探討FileNotFoundException的成因、解決方案以及預(yù)防措施,幫助開發(fā)者理解和避免此類問題,需要的朋友可以參考下2024-06-06java使用zookeeper實現(xiàn)的分布式鎖示例
這篇文章主要介紹了java使用zookeeper實現(xiàn)的分布式鎖示例,需要的朋友可以參考下2014-05-05關(guān)于Spring多數(shù)據(jù)源TransactionManager沖突的解決方案
這篇文章主要介紹了關(guān)于Spring多數(shù)據(jù)源TransactionManager沖突的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07IntelliJ IDEA之高效代碼插件RainBow Brackets詳解
這篇文章主要介紹了IntelliJ IDEA之高效代碼插件RainBow Brackets詳解,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12