设计模式-迭代器模式

文章目录

迭代器模式

如:集合中常见的迭代器

定义:迭代器模式提供了一种方法顺序访问一个聚合对象中的各个元素,而又无需暴露该对象的内部实现,这样既可以做到不暴露集合的内部结构,又可让外部代码透明地访问集合内部的数据

比如LeetCode:173. 二叉搜索树迭代器,可以内部各种方式实现,但是对外就是如下两个方法

java 复制代码
public int next()

public boolean hasNext()
  • ac
java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class BSTIterator {
    // O(h)的存储
    Stack<TreeNode> sta;

    private void left2Stack(TreeNode root){
        while (root != null){
            sta.push(root);
            root = root.left;
        }
    }

    public BSTIterator(TreeNode root) {
        sta = new Stack<>();
        left2Stack(root);
    }

    /** @return the next smallest number */
    public int next() {
        TreeNode node = sta.pop();
        if(node.right != null){
            left2Stack(node.right);
        }
        return node.val;
    }

    /** @return whether we have a next smallest number */
    public boolean hasNext() {
        return ! sta.isEmpty();
    }
}

/**
 * Your BSTIterator object will be instantiated and called as such:
 * BSTIterator obj = new BSTIterator(root);
 * int param_1 = obj.next();
 * boolean param_2 = obj.hasNext();
 */
相关推荐
小帅学编程1 分钟前
Maven
java·maven
悟能不能悟26 分钟前
在 MyBatis 的xml中,什么时候大于号和小于号可以不用转义
xml·java·mybatis
hqxstudying27 分钟前
深入解析 Java List 实现类的底层原理
java·数据结构·算法·链表
猫头虎31 分钟前
2025最新Python 100个常用函数在线体验项目
android·java·python·pycharm·django·pandas·pip
学统计的程序员31 分钟前
JAVA锁机制:对象锁与类锁
java·开发语言
苹果醋31 小时前
vuex4.0用法
java·运维·spring boot·mysql·nginx
晴空月明1 小时前
Spring IoC容器与依赖注入深度解析
java
Java初学者小白1 小时前
秋招Day14 - MySQL - 数据库架构
java·数据库·数据库架构
转码的小石2 小时前
深入Java大厂面试:从Spring框架到微服务架构的技术解析
java·spring boot·spring cloud·微服务·junit·spring security·hibernate
大熊程序猿2 小时前
quartz 表达式最近10次执行时间接口编写
java·服务器·前端