题目描述
给定一个字符串 s 表示一个整数嵌套列表,实现一个解析它的语法分析器并返回解析的结果 NestedInteger
。
列表中的每个元素只可能是整数或整数嵌套列表
示例 1:
输入:s = "324",
输出:324
解释:你应该返回一个 NestedInteger 对象,其中只包含整数值 324。
示例 2:
输入:s = "[123,[456,[789]]]",
输出:[123,[456,[789]]]
解释:返回一个 NestedInteger 对象包含一个有两个元素的嵌套列表:
1. 一个 integer 包含值 123
2. 一个包含两个元素的嵌套列表:
i. 一个 integer 包含值 456
ii. 一个包含一个元素的嵌套列表
a. 一个 integer 包含值 789
提示:
1 <= s.length <= 5 * 104
s
由数字、方括号"[]"
、负号'-'
、逗号','
组成- 用例保证
s
是可解析的NestedInteger
- 输入中的所有值的范围是
[-106, 106]
今天的题目我表示真的看不太懂,于是只能直接去看官方的解法。
官方
方法一:深度优先搜索
思路
根据题意,一个NestedInteger 实例只能包含下列两部分之一:1)一个整数;2)一个列表,列表中的每个元素都是一个NestedInteger 实例。据此,NestedInteger 是通过递归定义的,因此也可以用递归的方式来解析。
从左至右遍历 ss,
如果第一位是‘[’ 字符,则表示待解析的是一个列表,从 ‘[’ 后面的字符开始又是一个新的NestedInteger 实例,我们仍调用解析函数来解析列表的元素,调用结束后如果遇到的是 , 字符,表示列表仍有其他元素,需要继续调用。如果是 ‘]’ 字符,表示这个列表已经解析完毕,可以返回NestedInteger 实例。
否则,则表示待解析的NestedInteger 只包含一个整数。我们可以从左至右解析这个整数,并注意是否是负数,直到遍历完或者遇到非数字字符(‘]’ 或 ‘,’),并返回NestedInteger 实例。
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);
}
}
}
简单理解就是一个整数数组嵌套的意思,所以要用到递归的方法,而递归往往可以用栈替代,所以官方的第二种解法就是运用栈的思路去求解的。
只能说类这方面我还不是很熟悉,还是要多看看代码,多学习啊。