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

举报
bug菌 发表于 2024/01/30 13:06:51 2024/01/30
【摘要】 🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!! 前言多维数组是Java中一个非常重要的数据结构,它允许我们存储和操作更加复杂的数据。在上一篇文章中,我们介绍了Java中的多维数组的基本概念和语法。本文将介绍如何高效地访问多维数组,以及如何遍历多维数组中的元素。 摘要本文将会介绍:如何高效地访问...

🏆本文收录于「滚雪球学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编程,就像滚雪球一样,越滚越大,指数级提升。

📣关于我


我是bug菌,CSDN | 掘金 | infoQ | 51CTO 等社区博客专家,历届博客之星Top30,掘金年度人气作者Top40,51CTO年度博主Top12,华为云 | 阿里云| 腾讯云等社区优质创作者,全网粉丝合计15w+ ;硬核微信公众号「猿圈奇妙屋」,欢迎你的加入!免费白嫖最新BAT互联网公司面试题、4000G pdf电子书籍、简历模板等海量资料。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。