• Java实现 LeetCode 284 顶端迭代器


    284. 顶端迭代器

    给定一个迭代器类的接口,接口包含两个方法: next() 和 hasNext()。设计并实现一个支持 peek() 操作的顶端迭代器 – 其本质就是把原本应由 next() 方法返回的元素 peek() 出来。

    示例:

    假设迭代器被初始化为列表 [1,2,3]。

    调用 next() 返回 1,得到列表中的第一个元素。
    现在调用 peek() 返回 2,下一个元素。在此之后调用 next() 仍然返回 2。
    最后一次调用 next() 返回 3,末尾元素。在此之后调用 hasNext() 应该返回 false。
    进阶:你将如何拓展你的设计?使之变得通用化,从而适应所有的类型,而不只是整数型?

    // Java Iterator interface reference:
    // https://docs.oracle.com/javase/8/docs/api/java/util/Iterator.html
    class PeekingIterator implements Iterator<Integer> {
    
    private Iterator<Integer> iterator;
        private Integer cache = null; // 第一次peek时, 缓存迭代的元素
    
        public PeekingIterator(Iterator<Integer> iter) {
            iterator = iter;
        }
    
        public Integer peek() {
            if (cache == null)
                cache = iterator.next();
            return cache;
        }
    
        @Override
        public Integer next() {
            if (cache == null)
                return iterator.next();
            Integer temp = cache;
            cache = null;
            return temp;
        }
    
        @Override
        public boolean hasNext() {
            return cache != null || iterator.hasNext();
        }
    }
    
  • 相关阅读:
    C#_WinForm接收命令行参数
    SQLite不支持的SQL语法总结
    Thirft框架介绍
    jquery获取复选框的值
    REST构架风格介绍:状态表述转移
    RESTful HTTP的实践infoQ
    C#如何在webBrowser1控件通过TagName,Name查找元素(没有ID时)遍历窗体元素
    Html TO Ubb and Ubb TO Html
    SQL 位运算
    Memcached真的过时了吗?【转帖】
  • 原文地址:https://www.cnblogs.com/a1439775520/p/12946612.html
Copyright © 2020-2023  润新知