mini-parser

复制代码
https://leetcode.com/problems/mini-parser/

/**
 * // This is the interface that allows for creating nested lists.
 * // You should not implement it, or speculate about its implementation
 * public interface NestedInteger {
 *     // Constructor initializes an empty nested list.
 *     public NestedInteger();
 *
 *     // Constructor initializes a single integer.
 *     public NestedInteger(int value);
 *
 *     // @return true if this NestedInteger holds a single integer, rather than a nested list.
 *     public boolean isInteger();
 *
 *     // @return the single integer that this NestedInteger holds, if it holds a single integer
 *     // Return null if this NestedInteger holds a nested list
 *     public Integer getInteger();
 *
 *     // Set this NestedInteger to hold a single integer.
 *     public void setInteger(int value);
 *
 *     // Set this NestedInteger to hold a nested list and adds a nested integer to it.
 *     public void add(NestedInteger ni);
 *
 *     // @return the nested list that this NestedInteger holds, if it holds a nested list
 *     // Return null if this NestedInteger holds a single integer
 *     public List<NestedInteger> getList();
 * }
 */
public class Solution {
    public NestedInteger deserialize(String s) {
        if (s.equals("")) {
            return new NestedInteger();
        }
        if (s.startsWith("[")) {
            return impl(s.substring(1, s.length()-1));
        }
        return new NestedInteger(Integer.parseInt(s));
    }
    
    private NestedInteger impl(String s) {
        if (s.equals("")) {
            return new NestedInteger();
        }
        char [] chList = s.toCharArray();
        int wrap = 0;
        int left = 0;
        NestedInteger ret = new NestedInteger();
        for (int i = 0; i < chList.length; i++) {
            if (chList[i] == '[') {
                wrap++;
            }
            else if (chList[i] == ']') {
                wrap--;
            }
            else if (chList[i] == ',' && wrap == 0) {
                ret.add(deserialize(s.substring(left, i)));
                left = i + 1;
            }
        }
        ret.add(deserialize(s.substring(left, chList.length)));
        return ret;
    }
}
复制代码

 

posted @   blcblc  阅读(328)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示