0

0

迭代器

王林

王林

发布时间:2024-07-24 08:19:07

|

1238人浏览过

|

来源于dev.to

转载

bst 是可迭代的,因为它被定义为 java.lang.iterable 接口的子类型。

方法inorder()preorder()postorder()以二叉树的形式显示inorderpreorderpostorder中的元素。这些方法仅限于显示树中的元素。如果您希望处理二叉树中的元素而不是显示它们,则不能使用这些方法。回想一下,提供了一个迭代器来遍历集合或列表中的元素。您可以在二叉树中应用相同的方法来提供遍历二叉树中元素的统一方式。

java.lang.Iterable接口定义了iterator方法,该方法返回java.util.Iterator接口的实例。 java.util.Iterator 接口(见下图)定义了迭代器的共同特性。

迭代器

Tree 接口扩展了 java.lang.Iterable。由于BSTAbstractTree的子类,并且AbstractTree实现了Tree,所以BSTIterable的子类型。 Iterable 接口包含 iterator() 方法,该方法返回 java.util.Iterator.

的实例

您可以按中序、前序或后序遍历二叉树。由于inorder的使用频率很高,所以我们将使用inorder来遍历二叉树中的元素。我们定义一个名为InorderIterator的迭代器类来实现BST.java中的java.util.Iterator接口(第219-263行)。 iterator 方法仅返回 InorderIterator 的实例(第 215 行)。

Superflow Rewrite
Superflow Rewrite

AI辅助高效网站设计、协作、注释工具,迭代和发布网站的最快方式

下载

InorderIterator 构造函数调用 inorder 方法(第 225 行)。 inorder(root) 方法(第 234-239 行)将树中的所有元素存储在 list 中。元素按中序.

遍历

一旦创建了Iterator对象,它的current值就被初始化为0(第222行),它指向列表中的第一个元素。调用 next() 方法返回当前元素,并将 current 移动到指向列表中的下一个元素(第 250 行)。

hasNext()方法检查current是否仍在list的范围内(第243行)。

remove()

方法从树中删除当前元素(第 256 行)。然后,创建一个新列表(第 257-258 行)。请注意,current不需要更改。 下面的代码给出了一个测试程序,它将字符串存储在 BST 中并以大写形式显示所有字符串。

迭代器foreach 循环(第 15-16 行)使用迭代器来遍历树中的所有元素。

迭代器是一种重要的软件设计模式。它提供了一种遍历容器中元素的统一方法,同时隐藏容器的结构细节。通过实现相同的接口

java.util.Iterator

,您可以编写一个以相同方式遍历所有容器的元素的程序。

java.util.Iterator

定义了一个前向迭代器,它向前遍历迭代器中的元素,每个元素只能遍历一次。 Java API 还提供了java.util.ListIterator,支持向前和向后遍历。如果您的数据结构保证灵活遍历, 您可以将迭代器类定义为 java.util.ListIterator
. 的子类型 迭代器的实现效率不高。每次通过迭代器删除一个元素时,都会重建整个列表(BST.java 中的第 257 行)。客户端应始终使用

BinraryTree

类中的 delete 方法来删​​除元素。为了防止用户在迭代器中使用remove方法,请按如下方式实现迭代器: 公共无效删除(){

抛出新的 UnsupportedOperationException

(“不支持从迭代器中删除元素”);
}

使迭代器类不支持

remove

方法后,您可以更高效地实现迭代器,而无需维护树中元素的列表。您可以使用堆栈来存储节点,堆栈顶部的节点包含 next() 方法要返回的元素。如果树是平衡的,最大堆栈大小将为 O(logn)。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

71

2025.12.04

php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

71

2025.12.04

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1498

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

623

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

592

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

587

2024.04.29

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.9万人学习

C# 教程
C# 教程

共94课时 | 7.6万人学习

Java 教程
Java 教程

共578课时 | 51.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号