🎁 迎长周末,VIP通行证6个月限时优惠$50 off 🎁 点击查看详情
查看: 358|回复: 4
收起左侧

[高频题] Design an iterator for a collection of collections

|只看干货
本楼: 👍   100% (1)
 
 
0% (0)   👎
全局: 👍   89% (2243)
 
 
10% (274)    👎

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
Design an iterator for a collection of collections in java. The iterator should hide the nesting, allowing you to iterate all of the elements belonging to all of the collections as if you were working with a single collection

https://stackoverflow.com/questi ... tion-of-collections

sample solution
  1. public class MultiIterator <T> implements Iterator<T>{

  2.     private Iterator<? extends Collection<T>> it;
  3.     private Iterator<T> innerIt;
  4.     private T next;
  5.     private boolean hasNext = true;

  6.     public MultiIterator(Collection<? extends Collection<T>> collections) {
  7.         it = collections.iterator();   
  8.         prepareNext();
  9.     }

  10.     private void prepareNext() {
  11.         do {
  12.             if (innerIt == null || !innerIt.hasNext()) {
  13.                 if (!it.hasNext()) {
  14.                     hasNext = false;
  15.                     return;
  16.                 } else
  17.                     innerIt = it.next().iterator();
  18.             }
  19.         } while (!innerIt.hasNext());

  20.         next = innerIt.next();
  21.     }

  22.     @Override
  23.     public boolean hasNext() {
  24.         return hasNext;
  25.     }

  26.     @Override
  27.     public T next() {
  28.         if (!hasNext)
  29.             throw new NoSuchElementException();
  30.         T res = next;
  31.         prepareNext();
  32.         return res;
  33.     }

  34.     @Override
  35.     public void remove() {
  36.         //TODO
  37.     }

  38. }
复制代码

评分

参与人数 1大米 +1 收起 理由
14417335 + 1 给你点个赞!

查看全部评分


上一篇:[刷题笔记] 刷题性价比之王: 宽度优先搜索
下一篇:算法面试必刷100题
TerryYu 2022-5-2 11:43:48 | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   100% (72)
 
 
0% (0)    👎
支持楼主大侠
回复

使用道具 举报

 楼主| Chasedream.df 2022-5-2 12:03:38 | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   89% (2243)
 
 
10% (274)    👎
Tree Iterator
  1. /**
  2. * An iterator that iterates through a tree using in-order tree traversal
  3. * allowing a sorted sequence.
  4. *
  5. */
  6. public class Iterator {

  7.     private Stack<Node> stack = new Stack<>();
  8.     private Node current;

  9.     private Iterator(Node argRoot) {
  10.         current = argRoot;
  11.     }

  12.     public Node next() {
  13.         while (current != null) {
  14.             stack.push(current);
  15.             current = current.left;
  16.         }


  17.         current = stack.pop();
  18.         Node node = current;
  19.         current = current.right;

  20.         return node;
  21.     }

  22.     public boolean hasNext() {
  23.         return (!stack.isEmpty() || current != null);
  24.     }

  25.     public static Iterator iterator(Node root) {
  26.         return new Iterator(root);
  27.     }
  28. }
复制代码

评分

参与人数 1大米 +1 收起 理由
14417335 + 1 给你点个赞!

查看全部评分

回复

使用道具 举报

 楼主| Chasedream.df 2022-5-2 12:05:30 | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   89% (2243)
 
 
10% (274)    👎
Given a list of k sorted iterators. Implement MergingIterator to merge them. If you are not familiar with Iterators check similar questions.
  1. public interface Iterator {
  2.   /**
  3.    * [url=home.php?mod=space&uid=160137]@return[/url] True if the there is a next element
  4.    */
  5.   boolean hasNext();
  6.   /**
  7.    * @return next Highest number and removes the items from the stream.
  8.    */
  9.   int getNextHighestNumber();
  10. }

  11. class MergedIterator {
  12.     List<Iterator> _listIters;
  13.     PriorityQueue<Pair<?,?>> maxHeap;
  14.   /**
  15.    * Construct MergedIterator.
  16.    * @param iterators list of iterator
  17.    */
  18.   MergedIterator(List<Iterator> iterators) {
  19.       if (iterators == null || iterators.size() <= 0) throw new Exception("");
  20.      _listIters = iterators;
  21.      maxHeap = new PriorityQueue<Pair<Int, Iterator>, >(new MyCompartor());
  22.      for (Iterator iter: _listIters) {
  23.           if (iter.hasNext())
  24.               maxHeap.insert(new Pair(iter.getNextHighestNumber(), iter));
  25.       }
  26.   }

  27.   /**
  28.    * @return true if there is a next element.
  29.    */
  30.   boolean hasNext() {
  31.     return maxHeap.size() > 0;
  32. }

  33.   /**
  34.    * @return next max element across all the iterators.
  35.    */
  36.   int getNextHighestNumber() {
  37.       if (!hasNext()) throw new Exception("Empty");
  38.       Pair pair = maxHeap.pop();
  39.       int num = pair.getFirst();
  40.       Iterator iter = pair.getSecond();
  41.       if (iter.hasNext())
  42.         maxHeap.insert(new Pair(iter.getNextHighestNumber(), iter));
  43.       return num;

  44.   }

  45. }
复制代码

评分

参与人数 1大米 +1 收起 理由
14417335 + 1 给你点个赞!

查看全部评分

回复

使用道具 举报

 楼主| Chasedream.df 2022-5-2 12:06:10 | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   89% (2243)
 
 
10% (274)    👎
Deep Iterator
  1. class DeepIterator implements Iterator<Object> {
  2.     Stack<Iterator<Object>> itrs;
  3.     Object curValue;
  4.     public DeepIterator(ArrayList<Object> inputList) {
  5.         itrs = new Stack<Iterator<Object>>();
  6.         itrs.push(inputList.iterator());
  7.     }
  8.    
  9.     @Override
  10.     public boolean hasNext() {
  11.        if (itrs.isEmpty()) {
  12.            return false;
  13.        }
  14.        Iterator<Object> curIter = itrs.peek();
  15.        while (curIter.hasNext()) {
  16.            Object nextObj = curIter.next();
  17.            if (obj instanceof ArrayList) {
  18.                if ((ArrayList(obj)).size() == 0) {
  19.                    continue;
  20.                } else {
  21.                    itrs.push((ArrayList(obj)).iterator());
  22.                    return hasNext();
  23.                }
  24.            } else {
  25.                curValue = (Object)nextObj;
  26.                return true;
  27.            }
  28.            
  29.        }
  30.        itrs.pop();
  31.        return hasNext();
  32.     }

  33.     @Override
  34.     public Object next() {
  35.         if (hasNext()) {
  36.             return curValue;
  37.         } else {
  38.             return null;
  39.         }
  40.         
  41.   
  42.     }
  43. }
复制代码

评分

参与人数 1大米 +1 收起 理由
14417335 + 1 欢迎分享你知道的情况,会给更多积分奖励!

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表