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

题目:

题解:

cpp 复制代码
struct NestedIterator {
    int *vals;
    int size;
    int cur;
};

void dfs(struct NestedIterator *iter, struct NestedInteger **nestedList, int nestedListSize) {
    for (int i = 0; i < nestedListSize; i++) {
        if (NestedIntegerIsInteger(nestedList[i])) {
            (iter->vals)[(iter->size)++] = NestedIntegerGetInteger(nestedList[i]);
        } else {
            dfs(iter, NestedIntegerGetList(nestedList[i]), NestedIntegerGetListSize(nestedList[i]));
        }
    }
}

struct NestedIterator *nestedIterCreate(struct NestedInteger **nestedList, int nestedListSize) {
    struct NestedIterator *ret = malloc(sizeof(struct NestedIterator));
    ret->vals = malloc(sizeof(int) * 20001);
    ret->size = 0;
    ret->cur = 0;
    dfs(ret, nestedList, nestedListSize);
    return ret;
}

bool nestedIterHasNext(struct NestedIterator *iter) {
    return iter->cur != iter->size;
}

int nestedIterNext(struct NestedIterator *iter) {
    return (iter->vals)[(iter->cur)++];
}

void nestedIterFree(struct NestedIterator *iter) {
    free(iter->vals);
    free(iter);
}
相关推荐
Riemann~~1 小时前
C语言嵌入式风格
c语言·开发语言
Once_day2 小时前
GCC编译(1)入门概述
c语言·编译和链接
期末考复习中,蓝桥杯都没时间学了2 小时前
力扣刷题19
算法·leetcode·职场和发展
爱编码的小八嘎3 小时前
第2章 认识CPU-2.2 16位微处理器(2)
c语言
踩坑记录3 小时前
递归回溯本质
leetcode
好学且牛逼的马4 小时前
【Hot100|25-LeetCode 142. 环形链表 II - 完整解法详解】
算法·leetcode·链表
01二进制代码漫游日记5 小时前
自定义类型:联合和枚举(一)
c语言·开发语言·学习·算法
样例过了就是过了6 小时前
LeetCode热题100 和为 K 的子数组
数据结构·算法·leetcode
二年级程序员6 小时前
单链表算法思路详解(下)
c语言·数据结构·算法
Sunsets_Red6 小时前
浅谈随机化与模拟退火
java·c语言·c++·python·算法·c#·信息学竞赛