设计模式-迭代器模式

文章目录

迭代器模式

如:集合中常见的迭代器

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

比如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();
 */
相关推荐
江节胜-胜行全栈AI16 分钟前
Java-代码段-http接口调用自身服务中的其他http接口(mock)-并建立socket连接发送和接收报文实例
java·开发语言·http
写bug写bug34 分钟前
一文掌握 Spring 的启动扩展点
java·后端·spring
别来无恙14938 分钟前
Java枚举详解:从基础到高级应用
java·开发语言·枚举
地藏Kelvin41 分钟前
Spring Ai 从Demo到搭建套壳项目(一)初识与实现与deepseek对话模式
java·人工智能·后端
论迹1 小时前
【JavaEE】-- 文件操作和IO
java·java-ee·io·文件操作
程序员清风1 小时前
快手一面:RocketMQ顺序消息如何增加吞吐量?
java·后端·面试
用户0595661192091 小时前
Java 编程进阶实操中工具集整合组件封装方法与使用指南详解
java
jian110581 小时前
Mac redis下载和安装
java·redis
天天摸鱼的java工程师1 小时前
Spring Boot 整合 MinIO 实现全场景文件管理:从基础操作到分片上传的完整方案
java·后端
天天摸鱼的java工程师1 小时前
Git 分支管理规范:从理论到实战的企业级最佳实践
java·git·后端