有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪" />

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

Go Java 算法之迷你語(yǔ)法分析器示例詳解

 更新時(shí)間:2022年08月23日 09:31:53   作者:黃丫丫  
這篇文章主要為大家介紹了Go Java 算法之迷你語(yǔ)法分析器示例詳解,
有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

迷你語(yǔ)法分析器

給定一個(gè)字符串 s 表示一個(gè)整數(shù)嵌套列表,實(shí)現(xiàn)一個(gè)解析它的語(yǔ)法分析器并返回解析的結(jié)果 NestedInteger 。

列表中的每個(gè)元素只可能是整數(shù)或整數(shù)嵌套列表

  • 示例 1:

輸入:s = "324",

輸出:324

解釋:你應(yīng)該返回一個(gè) NestedInteger 對(duì)象,其中只包含整數(shù)值 324。

  • 示例 2:

輸入:s = "[123,[456,[789]]]",

輸出:[123,[456,[789]]]

解釋:返回一個(gè) NestedInteger 對(duì)象包含一個(gè)有兩個(gè)元素的嵌套列表:

一個(gè) integer 包含值 123

一個(gè)包含兩個(gè)元素的嵌套列表:

i. 一個(gè) integer 包含值 456

ii. 一個(gè)包含一個(gè)元素的嵌套列表

a. 一個(gè) integer 包含值 789  

提示:

  • 1 <= s.length <= 5 * 104
  • s 由數(shù)字、方括號(hào) "[]"、負(fù)號(hào) '-' 、逗號(hào) ','組成
  • 用例保證 s 是可解析的 NestedInteger
  • 輸入中的所有值的范圍是 [-106, 106]

方法一:深度優(yōu)先遍歷(Java)

根據(jù)題意,一個(gè) NestedInteger 實(shí)例只能包含下列兩部分之一:1)一個(gè)整數(shù);2)一個(gè)列表。

列表中的每個(gè)元素都是一個(gè) NestedInteger 實(shí)例。據(jù)此,NestedInteger 是通過(guò)遞歸定義的,因此也可以用遞歸的方式來(lái)解析。

注意序列化的String,有2個(gè)特殊含義,導(dǎo)致不能用String.split()。否則實(shí)現(xiàn)起來(lái)會(huì)比較困難。

逗號(hào): 表示分割“同層級(jí)”的元素

中括號(hào)[] : 表示1個(gè)List,可以有兄弟節(jié)點(diǎn)Integer。

如果用逗號(hào)分割,可能會(huì)割裂了[]的List含義。

class Solution {
    int index = 0;
    public NestedInteger deserialize(String s) {
        if (s.charAt(index) == '[') {
            index++;
            NestedInteger ni = new NestedInteger();
            while (s.charAt(index) != ']') {
                ni.add(deserialize(s));
                if (s.charAt(index) == ',') {
                    index++;
                }
            }
            index++;
            return ni;
        } else {
            boolean negative = false;
            if (s.charAt(index) == '-') {
                negative = true;
                index++;
            }
            int num = 0;
            while (index < s.length() && Character.isDigit(s.charAt(index))) {
                num = num * 10 + s.charAt(index) - '0';
                index++;
            }
            if (negative) {
                num *= -1;
            }
            return new NestedInteger(num);
        }
    }
}

時(shí)間復(fù)雜度:O(n)

空間復(fù)雜度:O(n)

方法二:棧(Go)

我們只需關(guān)注字符串s中的[、],字符,其他字符均可轉(zhuǎn)為數(shù)字,初始化棧時(shí),將一個(gè)空的NestedInteger加入其中,防止越界。

順序遍歷,3 種情況:

[ :新建列表,入棧

數(shù)字和-:累加字符串

],:字符串加完,加入列表

]出棧,結(jié)果加入上級(jí)列表

func deserialize(s string) *NestedInteger {
  if s[0] != '[' {
    integer, _ := strconv.Atoi(s)
    nestedInteger := &NestedInteger{}
    nestedInteger.SetInteger(integer)
    return nestedInteger
  }
  stack, integer := []*NestedInteger{}, ""
  for _, ch := range s {
    switch ch {
      case '[':
        stack = append(stack, &NestedInteger{}) // 入棧
      case ']':
        fallthrough
      case ',':
        if integer != "" {
          int, _ := strconv.Atoi(integer)
          nestedInteger := NestedInteger{}
          nestedInteger.SetInteger(int)
          stack[len(stack) - 1].Add(nestedInteger)
          integer = ""
        }
        if ch == ']' && len(stack) > 1 { // 出棧
          stack[len(stack) - 2].Add(*stack[len(stack) - 1])
          stack = stack[:len(stack) - 1]
        }
      default:
        integer += string(ch)
    }
  }
  return stack[len(stack) - 1]
}

時(shí)間復(fù)雜度:O(n)

空間復(fù)雜度:O(n)

以上就是Go Java 算法之迷你語(yǔ)法分析器示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Go Java 算法語(yǔ)法分析器的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 關(guān)于Spring MVC同名參數(shù)綁定問(wèn)題的解決方法

    關(guān)于Spring MVC同名參數(shù)綁定問(wèn)題的解決方法

    Spring MVC中的參數(shù)綁定還是蠻重要的,最近在使用中遇到了同名參數(shù)綁定的問(wèn)題,想著總結(jié)分享出來(lái),下面這篇文章主要給大家介紹了關(guān)于Spring MVC同名參數(shù)綁定問(wèn)題的解決方法,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-08-08
  • 使用maven創(chuàng)建普通項(xiàng)目命令行程序詳解

    使用maven創(chuàng)建普通項(xiàng)目命令行程序詳解

    大部分使用maven創(chuàng)建的是web項(xiàng)目,這里使用maven創(chuàng)建一個(gè)命令行程序,目的是讓大家了解maven特點(diǎn)和使用方式,有需要的朋友可以借鑒參考下
    2021-10-10
  • Spring MVC 執(zhí)行流程的簡(jiǎn)述

    Spring MVC 執(zhí)行流程的簡(jiǎn)述

    這篇文章主要介紹了Spring MVC 執(zhí)行流程的簡(jiǎn)述,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Java超詳細(xì)透徹講解接口

    Java超詳細(xì)透徹講解接口

    接口是Java中最重要的概念之一,它可以被理解為一種特殊的類,不同的是接口的成員沒有執(zhí)行體,是由全局常量和公共的抽象方法所組成,本文給大家介紹Java接口,感興趣的朋友一起看看吧
    2022-05-05
  • Springboot集成mybatis與jsp過(guò)程詳解

    Springboot集成mybatis與jsp過(guò)程詳解

    這篇文章主要介紹了Springboot集成mybatis與jsp過(guò)程,Spring Boot是一種全新的框架(相對(duì)而言),是用來(lái)簡(jiǎn)化Spring應(yīng)用的初始搭建以及開發(fā)過(guò)程。該框架使用了特定的方式來(lái)進(jìn)行配置
    2021-09-09
  • Web Service 運(yùn)行原理詳細(xì)介紹

    Web Service 運(yùn)行原理詳細(xì)介紹

    這篇文章主要介紹了 Web Service 運(yùn)行原理詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • Java之經(jīng)典排序算法

    Java之經(jīng)典排序算法

    這篇文章主要介紹了Java的一些經(jīng)典排序算法,對(duì)Java算法感興趣的小伙伴可以詳細(xì)參考閱讀本文,對(duì)同學(xué)們有一定的參考價(jià)值
    2023-03-03
  • 詳解Java中方法重寫和方法重載的6個(gè)區(qū)別

    詳解Java中方法重寫和方法重載的6個(gè)區(qū)別

    方法重寫和方法重載都是面向?qū)ο缶幊讨?,那么方法重寫和方法重載有哪些區(qū)別,本文就詳細(xì)的來(lái)介紹一下,感興趣的可以了解一下
    2022-01-01
  • Springboot整合MongoDB進(jìn)行CRUD操作的兩種方式(實(shí)例代碼詳解)

    Springboot整合MongoDB進(jìn)行CRUD操作的兩種方式(實(shí)例代碼詳解)

    這篇文章主要介紹了Springboot整合MongoDB進(jìn)行CRUD操作的兩種方式,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-04-04
  • UrlRewrite 重寫url詳解及實(shí)例

    UrlRewrite 重寫url詳解及實(shí)例

    這篇文章主要介紹了UrlRewrite 重寫url詳解及實(shí)例的相關(guān)資料,重寫能美化,提高安全,有利于搜索引擎的收入等,需要的朋友可以參考下
    2016-12-12

最新評(píng)論