C++ | Leetcode C++题解之第341题扁平化嵌套列表迭代器

题目:

题解:

cpp 复制代码
class NestedIterator {
private:
    vector<int> vals;
    vector<int>::iterator cur;

    void dfs(const vector<NestedInteger> &nestedList) {
        for (auto &nest : nestedList) {
            if (nest.isInteger()) {
                vals.push_back(nest.getInteger());
            } else {
                dfs(nest.getList());
            }
        }
    }

public:
    NestedIterator(vector<NestedInteger> &nestedList) {
        dfs(nestedList);
        cur = vals.begin();
    }

    int next() {
        return *cur++;
    }

    bool hasNext() {
        return cur != vals.end();
    }
};
相关推荐
木井巳4 小时前
【递归算法】单词搜索
java·算法·leetcode·决策树·深度优先
handler014 小时前
【算法模板】最小生成树:稠密图选 Prim,稀疏图选 Kruskal
c语言·数据结构·c++·算法
许长安4 小时前
RPC 异步调用基本使用方法:基于官方helloworld-async 示例
c++·经验分享·笔记·rpc
Chase_______5 小时前
LeetCode 2461 & 1423:定长滑窗变体精讲,从 HashMap 判重到正难则反的转化技巧
算法·leetcode·职场和发展
sparEE5 小时前
c++面向对象:对象的赋值
开发语言·c++
此生决int5 小时前
快速复习之数据结构篇——栈和队列
数据结构·c++
H_BB5 小时前
第17届蓝桥杯备战历程
c++·算法·职场和发展·蓝桥杯
daad7776 小时前
记录一次上下文切换次数的统计
服务器·c++·算法
tankeven6 小时前
C++ Lambda 表达式
c++
fangzt20106 小时前
插件系统:让其他人也能给编辑器写节点
c++