385 Mini Parser
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 digits
0-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?