385 Mini Parser

1. Question

Given a nested list of integers represented as a string, implement a parser to deserialize it.

Each element is either an integer, or a list -- whose elements may also be integers or other lists.

Note: You may assume that the string is well-formed:

  • String is non-empty.

  • String does not contain white spaces.

  • String contains only digits0-9,[,-,,].

Example 1:

Given s = "324",

You should return a NestedInteger object which contains a single integer 324.

Example 2:

Given s = "[123,[456,[789]]]",

Return a NestedInteger object containing a nested list with 2 elements:

1. An integer containing value 123.
2. A nested list containing two elements:
    i.  An integer containing value 456.
    ii. A nested list with one element:
     a. An integer containing value 789.

2. Implementation

(1) Recursion

思路: 括号中的string相当于一个subproblem,所以当我们遇到左括号,可以递归地调用原来的方程,遇到右括号时,则跳出递归。总得思路其实和LC 224类似。

(2) Stack

既然可以用递归,就可以用stack模拟递归的过程,总体思路和递归一样,只是遇到左括号时,将结果入栈,遇到右括号时出栈而已

3. Time & Space Complexity

(1) Recursion: 时间复杂度O(n), 空间复杂度O(n)

(2) Stack: 时间复杂度O(n), 空间复杂度O(n)

Last updated

Was this helpful?