欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java?LeetCode普通字符串模擬題解示例

 更新時間:2023年02月03日 10:42:34   作者:宮水三葉的刷題日記  
這篇文章主要為大家介紹了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的解決方案

    在Java編程中,FileNotFoundException 是一種常見的受檢異常,通常發(fā)生在試圖打開一個不存在的文件或文件路徑錯誤時,本文將詳細探討FileNotFoundException的成因、解決方案以及預(yù)防措施,幫助開發(fā)者理解和避免此類問題,需要的朋友可以參考下
    2024-06-06
  • java排查死鎖示例

    java排查死鎖示例

    這篇文章主要介紹了java排查死鎖示例,通過java中簡單的死鎖示例引出四種排查死鎖的工具,詳細講解請看全文,希望對大家有所幫助
    2021-08-08
  • java使用zookeeper實現(xiàn)的分布式鎖示例

    java使用zookeeper實現(xiàn)的分布式鎖示例

    這篇文章主要介紹了java使用zookeeper實現(xiàn)的分布式鎖示例,需要的朋友可以參考下
    2014-05-05
  • Java喚醒本地應(yīng)用的兩種方法詳解

    Java喚醒本地應(yīng)用的兩種方法詳解

    這篇文章主要為大家介紹了Java喚醒本地應(yīng)用的兩種方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • JavaEE微框架Spring Boot深入解讀

    JavaEE微框架Spring Boot深入解讀

    spring框架作為JavaEE框架領(lǐng)域的一款重要的開源框架,在企業(yè)應(yīng)用開發(fā)中有著很重要的作用。接下來通過本文給大家介紹JavaEE微框架Spring Boot深入解讀,需要的朋友可以參考下
    2017-04-04
  • SpringMVC中文件的上傳與下載詳細解析

    SpringMVC中文件的上傳與下載詳細解析

    這篇文章主要介紹了SpringMVC中文件的上傳與下載詳細解析,在開發(fā)中有遇到文件上傳下載的功能需求,今天就來說一下前后端的實現(xiàn)和要注意的地方,需要的朋友可以參考下
    2024-01-01
  • Java HashMap算法原理詳細講解

    Java HashMap算法原理詳細講解

    在java開發(fā)中,HashMap是最常用、最常見的集合容器類之一,文中通過示例代碼介紹HashMap為啥要二次Hash,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-02-02
  • Spring?boot?集成?MQTT詳情

    Spring?boot?集成?MQTT詳情

    這篇文章主要介紹了Spring?boot?集成?MQTT詳情,MQTT是一種基于發(fā)布/訂閱模式的"輕量級"通訊協(xié)議,可以以極少的代碼和有限的帶寬為連接遠程設(shè)備提供實時可靠的消息服,下文更多相關(guān)介紹,需要的小伙伴可以參考一下
    2022-04-04
  • 關(guān)于Spring多數(shù)據(jù)源TransactionManager沖突的解決方案

    關(guān)于Spring多數(shù)據(jù)源TransactionManager沖突的解決方案

    這篇文章主要介紹了關(guān)于Spring多數(shù)據(jù)源TransactionManager沖突的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • IntelliJ IDEA之高效代碼插件RainBow Brackets詳解

    IntelliJ IDEA之高效代碼插件RainBow Brackets詳解

    這篇文章主要介紹了IntelliJ IDEA之高效代碼插件RainBow Brackets詳解,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12

最新評論