三种方法遍历二叉树_java遍历arraylist

三种方法遍历二叉树_java遍历arraylistArrayList的多种遍历方法

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用
一:使用For循环遍历

   
   
   
  1. package threeJeHe;
  2. import java.awt.List;
  3. import java.util.ArrayList;
  4. public class ForTraversalDemo {
  5. public static void main(String[] args) {
  6. ArrayList<Integer> list = new ArrayList<Integer>();//创建列表
  7. for (int i = 0; i < 10; i++) {//向列表中添加10个元素
  8. list.add(i);
  9. }
  10. System.out.println("列表中的元素为: " + list);
  11. System.out.println("列表中的奇数序号元素为: " );
  12. for (int i = 0; i < list.size(); i++){
  13. System.out.print(list.get(i) + " ");
  14. }
  15. }
  16. }

二:使用Iterator遍历
   
   
   
  1. package threeJeHe;
  2. import java.util.ArrayList;
  3. import java.util.Iterator;
  4. public class IteratorTraversalDemo {
  5. public static void main(String[] args) {
  6. ArrayList<Integer> list = new ArrayList<Integer>();//创建列表
  7. for (int i = 0; i < 10; i++) {//增加10个元素
  8. list.add(i);
  9. }
  10. System.out.println("列表中的全部元素为: ");
  11. for(Iterator<Integer> it = list.iterator();it.hasNext();) {
  12. System.out.print(it.next() + " ");
  13. }
  14. }
  15. }

对比这两种方法,我觉得使用iterator()这种迭代方法最为简单点。例如:Iterator可以通过循环输出类集中的内容,从而获得或删除元素。
详细来说,在通过迭代方法访问类集之前,必须得到一个迭代方法。
下面给出使用迭代方法循环输出类集内容的操作步骤:
(1)通过调用类集的iterator() 方法获得对类集的迭代方法
(2)建立一个调用hasNext()方法的循环,只要hasNext()返回true,就进行循环迭代
(3)在循环内部,通过调用next()方法来得到每一个元素
三、使用ListIterator逆序遍历ArrayList
源码如下:
  
  
  
  1. package one;
  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import java.util.ListIterator;
  5. public class ListIteratorDemo {
  6. public static void main(String[] args) {
  7. List<Integer> list = new ArrayList<Integer>();
  8. for (int i = 0; i < 10; i++) {
  9. list.add(i);
  10. }
  11. System.out.println("列表中全部的元素为: " + list);
  12. System.out.println("逆序输出的顺序为: ");
  13. ListIterator<Integer> li = list.listIterator();//获得listItegerator对象
  14. for(li = list.listIterator(); li.hasNext();) {
  15. li.next();
  16. }
  17. for(;li.hasPrevious();){
  18. System.out.print(li.previous() + " ");
  19. }
  20. }
  21. }

首先,先看API对ListIterator的讲解:
public interface ListIterator<E>
    
     extends 
     Iterator<E>
    

系列表迭代器,允许程序员按任一方向遍历列表、迭代期间修改列表,并获得迭代器在列表中的当前位置。ListIterator 没有当前元素;它的光标位置 始终位于调用 previous() 所返回的元素和调用 next() 所返回的元素之间。长度为 n 的列表的迭代器有 n+1 个可能的指针位置,如下面的插入符举例说明:

                      Element(0)   Element(1)   Element(2)   ... Element(n-1)

 cursor positions:  ^            ^            ^            ^                  ^

注意,remove() 和 set(Object) 方法不是 根据光标位置定义的;它们是根据对调用 next() 或 previous() 所返回的最后一个元素的操作定义的。

此接口是 Java Collections Framework 的成员。

我们都很清楚List和Set都有iterator() 来取得迭代器。对List来说,可以通过listIterator()取得其迭代器,但是两种迭代器在有些时候是不能通用的。Iterator和ListIterator主要的区别有以下几个方面:

1、ListIterato有add()方法,可以向List中添加对象,而Iterator不可以;

2、

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/188869.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 老男孩python课程_老男孩python课程[通俗易懂]

    老男孩python课程_老男孩python课程[通俗易懂]网页编程基础知识07w.avi–570.61MB网页编程基础知识06w.avi–305.27MB网页编程基础知识05w.avi–240.27MB网页编程基础知识04w.avi–313.23MB网页编程基础知识03w.avi–238.87MB网页编程基础知识02w.avi–184.95MB网页编程基础知识01w(此课程无声,后期补录).avi–868.18MBpython…

    2025年8月25日
    2
  • linux中mkdir命令含义,Linux中mkdir命令详解

    linux中mkdir命令含义,Linux中mkdir命令详解Linux 中 mkdir 命令详解 linuxmkdir 用来创建目录 要求创建目录的用户在当前目录中具有写权限 并且指定的目录名不能是当前目录中已有的目录 1 新建一个文件夹 one2 新建三个文件夹 three four five3 新建一个多层级文件夹 a 01 总结以上所述是小编给大家介绍的 Liunx 中 mkdir 命令详解 希望对大家有所帮助 如果大家有任何疑问请给我留言 小编会及

    2025年8月12日
    5
  • echart旭日图_基于Echarts4.0实现旭日图[通俗易懂]

    echart旭日图_基于Echarts4.0实现旭日图[通俗易懂]昨天Echarts4.0正式发布,随着4.0而来的是一系列的更新,挑几个主要的简单说明:1.展示方面通过增量渲染技术(4.0+)ECharts能够展现千万级的数据量2.针对移动端优化,移动端小屏上适于用手指在坐标系中进行缩放、平移。可选的SVG渲染模块让图表在移动端更加节省内存。3.增加多种渲染方案,可实现跨平台使用,现有三种方案,可渲染Canvas、SVG(4.0+)、VML的形式渲染图…

    2022年9月26日
    1
  • string、char中将单个字符转化为数字的几种方法[通俗易懂]

    在string中,strings="12345"如果想提取出每一位的数字,即分别得到1,2,3,4,5,怎么做呢需要用到substr和c_strsubstr:拷贝子字符串strings1=s.substr(0,2);//从下标0开始,拷贝2位则s1="12"; c_str:返回字符串的指针代码如下:intmain(){ strings="12345"; for…

    2022年4月18日
    206
  • 最详细的Vuex教程

    最详细的Vuex教程最详细的Vuex教程什么是Vuex?vuex是一个专门为vue.js设计的集中式状态管理架构。状态?我把它理解为在data中的属性需要共享给其他vue组件使用的部分,就叫做状态。简单的说就是data中需要共用的属性。引入Vuex(前提是已经用Vue脚手架工具构建好项目)1、利用npm包管理工具,进行安装vuex。在控制命令行中输入下边的命令就可以了。npminstallvuex

    2022年6月9日
    29
  • 【Redis】Redis配置文件详解

    【Redis】Redis配置文件详解一、存放位置linux下一定要养成备份配置文件的习惯。我是将配置文件拷贝至/myredis目录下进行操作的;二、Units单位这个在配置文件开始位置1.配置大小单位,开头定义了一些基本的度量单位,只支持bytes,不支持bit;2.对大小写不敏感。三、INCLUDES1.和Struts2配置文件类似,可以通过includes包含,redis.c…

    2022年6月7日
    53

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号