滚雪球学Java(31):玩转多维数组:高效访问和遍历

简介: 【5月更文挑战第6天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!

🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!!


前言

多维数组是Java中一个非常重要的数据结构,它允许我们存储和操作更加复杂的数据。在上一篇文章中,我们介绍了Java中的多维数组的基本概念和语法。本文将介绍如何高效地访问多维数组,以及如何遍历多维数组中的元素。

摘要

本文将会介绍:

  • 如何高效地访问多维数组。
  • 如何使用嵌套循环遍历多维数组中的元素。
  • 如何使用Java8中的流式编程遍历多维数组。

正文

高效访问多维数组

在访问多维数组时,我们可以使用多重索引来访问数组中的特定元素。例如,对于一个二维数组,我们可以使用两个索引来表示其行和列。

int[][] arr = new int[2][3];
arr[1][2] = 5; //设置第二行第三列的值为5

当我们需要访问多维数组中的大量元素时,使用多重索引可能会变得非常低效。在这种情况下,我们可以使用一维数组来表示多维数组,从而实现更高效的访问。

例如,对于一个二维数组,我们可以将其表示为一个一维数组,并使用以下公式来计算每个元素的索引:

int[] arr = new int[6];
int index = row * numCols + col;
arr[index] = 5; //设置第二行第三列的值为5

在这里,row表示行数,numCols表示列数,col表示列数减1。通过使用一维数组,我们可以更快地访问数组中的元素。

对于更高维度的数组,我们可以使用类似的方法来访问数组。例如,对于一个三维数组,我们可以将其表示为一个一维数组,并使用以下公式来计算每个元素的索引:

int[] arr = new int[24];
int index = (depth * numRows + row) * numCols + col;
arr[index] = 5; //设置第二个面的第三行第四列的值为5

遍历多维数组

在处理多维数组时,我们通常需要遍历数组中的所有元素。使用嵌套循环可以轻松地遍历多维数组中的所有元素。

例如,以下代码将遍历一个二维数组:

int[][] arr = new int[2][3];
//初始化数组
for (int i = 0; i < arr.length; i++) {
   
    for (int j = 0; j < arr[i].length; j++) {
   
        System.out.print(arr[i][j] + " ");
    }
    System.out.println();
}

类似地,我们可以使用三重或更多重循环来遍历更高维度的数组。

Java8中的流式编程也提供了一种简单的方法来遍历多维数组。我们可以将多维数组转换为流,然后使用flatMapToInt方法将其降维为一个整数流。最后,我们可以使用forEach方法遍历每个元素。

例如,以下代码将遍历一个二维数组:

int[][] arr = new int[2][3];
//初始化数组
Arrays.stream(arr)
      .flatMapToInt(Arrays::stream)
      .forEach(i -> System.out.print(i + " "));

测试用例

public class MultiDimensionalArrayTest {
   

    @Test
    public void testAccessArray() {
   
        int[][] arr = new int[2][3];
        int[] oneD = new int[6];

        arr[1][2] = 5; //设置第二行第三列的值为5
        oneD[1 * 3 + 2] = 5; //设置第二行第三列的值为5

        assertEquals(oneD[1 * 3 + 2], arr[1][2]);
    }

    @Test
    public void testTraverseArray() {
   
        int[][] arr = new int[2][3];

        //初始化数组
        for (int i = 0; i < arr.length; i++) {
   
            for (int j = 0; j < arr[i].length; j++) {
   
                arr[i][j] = i * j;
            }
        }

        //使用嵌套循环遍历数组
        for (int i = 0; i < arr.length; i++) {
   
            for (int j = 0; j < arr[i].length; j++) {
   
                System.out.print(arr[i][j] + " ");
            }
            System.out.println();
        }

        //使用流式编程遍历数组
        Arrays.stream(arr)
              .flatMapToInt(Arrays::stream)
              .forEach(i -> System.out.print(i + " "));
    }
}

小结

在本文中,我们介绍了如何高效地访问多维数组,并展示了如何使用嵌套循环和流式编程遍历多维数组中的元素。在处理多维数组时,请记住使用高效的方法来访问和遍历数组,以避免低效或错误的代码。

附录源码

  如上涉及所有源码均已上传同步在Gitee,提供给同学们一对一参考学习,辅助你更迅速的掌握。

☀️建议/推荐你


  无论你是计算机专业的学生,还是对编程有兴趣的小伙伴,都建议直接毫无顾忌的学习此专栏「滚雪球学Java」,bug菌郑重承诺,凡是学习此专栏的同学,均能获取到所需的知识和技能,全网最快速入门Java编程,就像滚雪球一样,越滚越大,指数级提升。

目录
相关文章
|
7天前
|
存储 安全 Java
滚雪球学Java(60):深入解析Java中的Vector集合类!
【6月更文挑战第14天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
145 59
滚雪球学Java(60):深入解析Java中的Vector集合类!
|
1天前
|
存储 Java 测试技术
滚雪球学Java(66):Java之HashMap详解:深入剖析其底层实现与源码分析
【6月更文挑战第20天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
11 3
滚雪球学Java(66):Java之HashMap详解:深入剖析其底层实现与源码分析
|
2天前
|
存储 算法 Java
滚雪球学Java(65):深入理解Java中的Map接口:实现原理剖析
【6月更文挑战第19天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
6 3
滚雪球学Java(65):深入理解Java中的Map接口:实现原理剖析
|
3天前
|
存储 缓存 Java
滚雪球学Java(64):LinkedHashSet原理及实现解析
【6月更文挑战第18天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
11 1
滚雪球学Java(64):LinkedHashSet原理及实现解析
|
5天前
|
存储 缓存 算法
滚雪球学Java(62):HashSet的底层实现原理解析
【6月更文挑战第16天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
15 3
滚雪球学Java(62):HashSet的底层实现原理解析
|
6天前
|
存储 Java 测试技术
滚雪球学Java(61):从源码角度解读Java Set接口底层实现原理
【6月更文挑战第15天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
14 1
滚雪球学Java(61):从源码角度解读Java Set接口底层实现原理
|
8天前
|
存储 缓存 Java
滚雪球学Java(59):从基础到高阶:Java中LinkedList的操作指南
【6月更文挑战第13天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
12 1
滚雪球学Java(59):从基础到高阶:Java中LinkedList的操作指南
|
10天前
|
存储 Java 测试技术
滚雪球学Java(57):解密Java中List接口底层实现原理
【6月更文挑战第11天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
23 2
滚雪球学Java(57):解密Java中List接口底层实现原理
|
11天前
|
存储 Java 测试技术
滚雪球学Java(56):探究Java中Collection接口,理解集合框架的实现原理
【6月更文挑战第10天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
31 2
滚雪球学Java(56):探究Java中Collection接口,理解集合框架的实现原理
|
12天前
|
算法 Java 测试技术
滚雪球学Java(55):想让你的程序更有趣?加上这个Java的Random类的小技巧!
【6月更文挑战第9天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
18 2
滚雪球学Java(55):想让你的程序更有趣?加上这个Java的Random类的小技巧!