Given a nested list of integers, implement an iterator to flatten it.

Each element is either an integer, or a list -- whose elements may also be integers or other lists.

Example 1:
Given the list [[1,1],2,[1,1]],

By calling next repeatedly until hasNext returns false, the order of elements returned by next should be: [1,1,2,1,1].

Example 2:
Given the list [1,[4,[6]]],

By calling next repeatedly until hasNext returns false, the order of elements returned by next should be: [1,4,6].

这道题让我们建立压平嵌套链表的迭代器,关于嵌套链表的数据结构最早出现在Nested List Weight Sum中,而那道题是用的递归的方法来解的,而迭代器一般都是用迭代的方法来解的,而递归一般都需用栈来辅助遍历,由于栈的后进先出的特性,我们在对向量遍历的时候,从后往前把对象压入栈中,那么第一个对象最后压入栈就会第一个取出来处理,我们的hasNext()函数需要遍历栈,并进行处理,如果栈顶元素是整数,直接返回true,如果不是,那么移除栈顶元素,并开始遍历这个取出的list,还是从后往前压入栈,循环停止条件是栈为空,返回false,参见代码如下:

解法一:

  1. class NestedIterator {
  2. public:
  3. NestedIterator(vector<NestedInteger> &nestedList) {
  4. for (int i = nestedList.size() - ; i >= ; --i) {
  5. s.push(nestedList[i]);
  6. }
  7. }
  8.  
  9. int next() {
  10. NestedInteger t = s.top(); s.pop();
  11. return t.getInteger();
  12. }
  13.  
  14. bool hasNext() {
  15. while (!s.empty()) {
  16. NestedInteger t = s.top();
  17. if (t.isInteger()) return true;
  18. s.pop();
  19. for (int i = t.getList().size() - ; i >= ; --i) {
  20. s.push(t.getList()[i]);
  21. }
  22. }
  23. return false;
  24. }
  25. private:
  26. stack<NestedInteger> s;
  27. };

我们也可以使用deque来代替stack,实现思路和上面完全一样,参见代码如下:

解法二:

  1. class NestedIterator {
  2. public:
  3. NestedIterator(vector<NestedInteger> &nestedList) {
  4. for (auto a : nestedList) {
  5. d.push_back(a);
  6. }
  7. }
  8.  
  9. int next() {
  10. NestedInteger t = d.front(); d.pop_front();
  11. return t.getInteger();
  12. }
  13.  
  14. bool hasNext() {
  15. while (!d.empty()) {
  16. NestedInteger t = d.front();
  17. if (t.isInteger()) return true;
  18. d.pop_front();
  19. for (int i = ; i < t.getList().size(); ++i) {
  20. d.insert(d.begin() + i, t.getList()[i]);
  21. }
  22. }
  23. return false;
  24. }
  25.  
  26. private:
  27. deque<NestedInteger> d;
  28. };

虽说迭代器是要用迭代的方法,但是我们可以强行使用递归来解,怎么个强行法呢,就是我们使用一个队列queue,在构造函数的时候就利用迭代的方法把这个嵌套链表全部压平展开,然后在调用hasNext()和next()就很简单了:

解法三:

  1. class NestedIterator {
  2. public:
  3. NestedIterator(vector<NestedInteger> &nestedList) {
  4. make_queue(nestedList);
  5. }
  6.  
  7. int next() {
  8. int t = q.front(); q.pop();
  9. return t;
  10. }
  11.  
  12. bool hasNext() {
  13. return !q.empty();
  14. }
  15.  
  16. private:
  17. queue<int> q;
  18. void make_queue(vector<NestedInteger> &nestedList) {
  19. for (auto a : nestedList) {
  20. if (a.isInteger()) q.push(a.getInteger());
  21. else make_queue(a.getList());
  22. }
  23. }
  24. };

类似题目:

Nested List Weight Sum

Flatten 2D Vector

Zigzag Iterator

参考资料:

https://leetcode.com/discuss/95841/simple-solution-with-queue

https://leetcode.com/discuss/95892/concise-c-without-storing-all-values-at-initialization

LeetCode All in One 题目讲解汇总(持续更新中...)

[LeetCode] Flatten Nested List Iterator 压平嵌套链表迭代器的更多相关文章

  1. [LintCode] Flatten Nested List Iterator 压平嵌套链表迭代器

    Given a nested list of integers, implement an iterator to flatten it. Each element is either an inte ...

  2. [LeetCode] 341. Flatten Nested List Iterator 压平嵌套链表迭代器

    Given a nested list of integers, implement an iterator to flatten it. Each element is either an inte ...

  3. [Swift]LeetCode341. 压平嵌套链表迭代器 | Flatten Nested List Iterator

    Given a nested list of integers, implement an iterator to flatten it. Each element is either an inte ...

  4. [leetcode]341. Flatten Nested List Iterator展开嵌套列表的迭代器

    Given a nested list of integers, implement an iterator to flatten it. Each element is either an inte ...

  5. Leetcode: Flatten Nested List Iterator

    Given a nested list of integers, implement an iterator to flatten it. Each element is either an inte ...

  6. 【python】Leetcode每日一题-扁平化嵌套列表迭代器

    [python]Leetcode每日一题-扁平化嵌套列表迭代器 [题目描述] 给你一个嵌套的整型列表.请你设计一个迭代器,使其能够遍历这个整型列表中的所有整数. 列表中的每一项或者为一个整数,或者是另 ...

  7. [LeetCode] Nested List Weight Sum 嵌套链表权重和

    Given a nested list of integers, return the sum of all integers in the list weighted by their depth. ...

  8. 【LeetCode】341. Flatten Nested List Iterator 解题报告(Python&C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 递归+队列 栈 日期 题目地址:https://lee ...

  9. 【leetcode】341. Flatten Nested List Iterator

    题目如下: Given a nested list of integers, implement an iterator to flatten it. Each element is either a ...

随机推荐

  1. [原创]django+ldap实现单点登录(装饰器和缓存)

    前言 参考本系列之前的文章,我们已经搭建了ldap并且可以通过django来操作ldap了,剩下的就是下游系统的接入了,现在的应用场景,我是分了2个层次,第一层次是统一认证,保证各个系统通过ldap来 ...

  2. .NET 实现并行的几种方式(三)

    本随笔续接:.NET 实现并行的几种方式(二) 在前两篇随笔中,先后介绍了 Thread .ThreadPool .IAsyncResult (即 APM系列) .Task .TPL (Task Pa ...

  3. LeetCode Online Judge 1. Two Sum

    刷个题,击败0.17%... Given an array of integers, return indices of the two numbers such that they add up t ...

  4. java动态代理的2种实现方式

    java的动态代理在接java的api上有说明,这里就不写了.我理解的代理: 对特定接口中特定方法的功能进行扩展,这就是代理.代理是通过代理实例关联的调用处理程序对象调用方法. 下面通过一个例子看一下 ...

  5. python学习笔记(基础一:'hello world'、变量、字符编码)

    第一个python程序: Hello World程序 windows命令行中输入:python,进入python交互器,也可以称为解释器. print("Hello World!" ...

  6. gRPC源码分析2-Server的建立

    gRPC中,Server.Client共享的Class不是很多,所以我们可以单独的分别讲解Server和Client的源码. 通过第一篇,我们知道对于gRPC来说,建立Server是非常简单的,还记得 ...

  7. window环境下将solr6.3部署到tomcat中

    1.我下载的solr是6.3版本的,需要jdk1.8及以上,tomcat8 JDK1.8的下载地址:http://www.Oracle.com/technetwork/Java/javase/down ...

  8. 解决springmvc+mybatis+mysql中文乱码问题【转】

    这篇文章主要介绍了解决java中springmvc+mybatis+mysql中文乱码问题的相关资料,需要的朋友可以参考下 近日使用ajax请求springmvc后台查询mysql数据库,页面显示中文 ...

  9. SVG坐标系统

    SVG的画布.画布视区(viewBox).浏览器视窗的概念 画布 画布是绘制SVG内容的一块区域,理论上在所有维度上都是无限的.(也有人称为"SVG世界",但我觉得叫画布比较合适) ...

  10. 深化管理、提升IT的数据平台建设方案

    谈到信息化,每个企业有每个企业的业务模式,每个企业有每个企业不同的思考.落地有效的信息化建设一定紧跟着企业的发展,围绕业务和管理,来提升效率,创造价值. 对于企业如何在发展的不同阶段提升信息化建设,这 ...