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)題的解決方法
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)建的是web項(xiàng)目,這里使用maven創(chuàng)建一個(gè)命令行程序,目的是讓大家了解maven特點(diǎn)和使用方式,有需要的朋友可以借鑒參考下2021-10-10Springboot集成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-09Springboot整合MongoDB進(jìn)行CRUD操作的兩種方式(實(shí)例代碼詳解)
這篇文章主要介紹了Springboot整合MongoDB進(jìn)行CRUD操作的兩種方式,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04