什么是带有示例的 Java 中的交错数组?

简介: 什么是带有示例的 Java 中的交错数组?

Java 中的交错数组

交错数组,也称为数组数组,是一种数据结构,其中数组用于存储其他数组。交错数组的主要特征是主数组的每个元素可以具有不同的大小,从而允许在二维结构中使用可变的列长度。

为了理解 Jagged 数组的概念,让我们考虑一个例子。假设我们想要存储有关学生及其各自成绩的信息。我们可以创建一个交错数组来表示这个数据结构。这是它的外观:

使用交错数组的好处是,当每个子数组中的元素数量不同时,它可以灵活地存储数据。这在列数可能不同的情况下特别有用,例如在处理不规则数据或稀疏矩阵时。

总之,交错数组提供了一种灵活的方法来表示和使用数据结构,其中每个维度的大小都可能不同,这使它们成为某些编程场景中的强大工具。

示例 1

在上面的代码中,我们首先声明一个 2D 交错数组 jagged Array 有三行。但是,我们此时不指定列长度。接下来,我们将不同大小的数组分配给交错数组的每一行。第一行有三个元素,第二行有两个元素,第三行有四个元素。

最后,我们使用嵌套循环来迭代并打印其元素。外部循环迭代行,内部循环迭代每行的列。jaggedarray

文件名:JaggedArrayExample.java

爪哇岛

1
public class JaggedArrayExample {
2


3
    public static void main(String[] args) {
4


5
        int[][] jaggedArray = new int[3][];
6


7
        
8


9
        // Assigning different-sized arrays to the jagged array
10


11
        jaggedArray[0] = new int[] { 1, 2, 3, 4 };
12


13
        jaggedArray[1] = new int[] { 5, 6, 7 };
14


15
        jaggedArray[2] = new int[] { 8, 9 };
16


17
        
18


19
        // Accessing and printing the elements of the jagged array
20


21
        for (int i = 0; i < jaggedArray.length; i++) {
22


23
            for (int j = 0; j < jaggedArray[i].length; j++) {
24


25
                 System.out.print(jaggedArray[i][j] + " ");
26


27
            }
28


29
            System.out.println();
30


31
        }
32


33
    }
34


35
}

输出

1 2 3 4 

5 6 7 

8 9

示例 2

在上面的代码中,我们声明了一个 2D 交错数组 jaggedArray,并用不同年级的学生名字对其进行初始化。第一行表示一年级学生的姓名。第二行表示二年级学生的姓名,依此类推。

然后,我们使用嵌套循环遍历交错数组并打印每个年级的学生姓名。外部循环遍历行 (grades),内部循环遍历每个年级的列 (students)。

文件名: JaggedArrayExample.java

爪哇岛

1
public class JaggedArrayExample {
2


3
     public static void main(String[] args) {
4


5
        // Declare and initialize a 2D jagged array to store names of students in different grades
6


7
        String[][] jaggedArray = {
8


9
            { "Ram", "Laxman" },                           // Grade 1 students
10


11
            { "Rahul", "Gauri", "Komal" },                // Grade 2 students
12


13
            { "Ajinkya", "Virat", "Tejaswi", "Sanju" }      // Grade 3 students
14


15
        };
16


17
        
18


19
        // Accessing and printing the elements of the jagged array
20


21
        for (int i = 0; i < jaggedArray.length; i++) {   // Iterate over the rows (grades)
22


23
            System.out.print("Grade " + (i + 1) + " students: ");
24


25
            for (int j = 0; j < jaggedArray[i].length; j++) {  // Iterate over the columns (students) of each grade
26


27
                 System.out.print(jaggedArray[i][j] + " ");    // Print the name of each student
28


29
            }
30


31
            System.out.println();   // Move to the next line after printing the names of students in a grade
32


33
        }
34


35
     }
36


37
}

示例 3

在上面的代码中,我们有一个交错数组 jaggedArray,它在每行中存储不同的数字。第一行有 3 个元素,第二行有 2 个元素,第三行有 4 个元素,第四行有 1 个元素。然后

我们使用嵌套循环来迭代交错数组并计算每行的总和。外部循环迭代行,内部循环迭代每行的列。每行的总和是通过将该行中的所有元素相加来计算的。

文件名:JaggedArrayExample.java

爪哇岛

1
public class JaggedArrayExample {
2


3
     public static void main(String[] args) {
4


5
        int[][] jaggedArray = {
6


7
            { 1, 2, 3 },      // First row with three elements
8


9
            { 4, 5 },         // Second row with two elements
10


11
            { 6, 7, 8, 9 },   // Third row with four elements
12


13
            { 10 }            // Fourth row with one element
14


15
        };
16


17
        
18


19
        // Calculate the sum of each row and display the results
20


21
        for (int i = 0; i < jaggedArray.length; i++) {
22


23
            int rowSum = 0;
24


25
            for (int j = 0; j < jaggedArray[i].length; j++) {
26


27
                rowSum += jaggedArray[i][j];
28


29
            }
30


31
            System.out.println("Sum of row " + (i + 1) + ": " + rowSum);
32


33
        }
34


35
     }
36


37
}

输出

Sum of row 1: 6

Sum of row 2: 9

Sum of row 3: 30

Sum of row 4: 10
目录
相关文章
|
7天前
|
存储 Java
Java中的HashMap和TreeMap,通过具体示例展示了它们在处理复杂数据结构问题时的应用。
【10月更文挑战第19天】本文详细介绍了Java中的HashMap和TreeMap,通过具体示例展示了它们在处理复杂数据结构问题时的应用。HashMap以其高效的插入、查找和删除操作著称,而TreeMap则擅长于保持元素的自然排序或自定义排序,两者各具优势,适用于不同的开发场景。
18 1
|
19天前
|
存储 缓存 Java
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
这篇文章详细介绍了Java中的IO流,包括字符与字节的概念、编码格式、File类的使用、IO流的分类和原理,以及通过代码示例展示了各种流的应用,如节点流、处理流、缓存流、转换流、对象流和随机访问文件流。同时,还探讨了IDEA中设置项目编码格式的方法,以及如何处理序列化和反序列化问题。
50 1
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
|
6天前
|
存储 缓存 算法
Java 数组
【10月更文挑战第19天】Java 数组是一种非常实用的数据结构,它为我们提供了一种简单而有效的方式来存储和管理数据。通过合理地使用数组,我们能够提高程序的运行效率和代码的可读性。更加深入地了解和掌握 Java 数组的特性和应用,为我们的编程之旅增添更多的精彩。
21 4
|
6天前
|
存储 缓存 算法
提高 Java 数组性能的方法
【10月更文挑战第19天】深入探讨了提高 Java 数组性能的多种方法。通过合理运用这些策略,我们可以在处理数组时获得更好的性能表现,提升程序的运行效率。
13 2
|
15天前
|
存储 Java
Java“(array) <X> Not Initialized” (数组未初始化)错误解决
在Java中,遇到“(array) &lt;X&gt; Not Initialized”(数组未初始化)错误时,表示数组变量已被声明但尚未初始化。解决方法是在使用数组之前,通过指定数组的大小和类型来初始化数组,例如:`int[] arr = new int[5];` 或 `String[] strArr = new String[10];`。
|
17天前
|
Java
让星星⭐月亮告诉你,jdk1.8 Java函数式编程示例:Lambda函数/方法引用/4种内建函数式接口(功能性-/消费型/供给型/断言型)
本示例展示了Java中函数式接口的使用,包括自定义和内置的函数式接口。通过方法引用,实现对字符串操作如转换大写、数值转换等,并演示了Function、Consumer、Supplier及Predicate四种主要内置函数式接口的应用。
20 1
|
21天前
|
Java
Java数组动态扩容和动态缩减
Java数组动态扩容和动态缩减
17 3
|
27天前
|
Java API 网络安全
Java 发送邮件示例
本示例展示了如何使用Java编程语言发送电子邮件。通过利用JavaMail API,这段代码实现了从配置SMTP服务器,设置邮件属性,到发送邮件的全过程,为开发者提供了实用的参考。
|
26天前
|
存储 算法 Java
Java一分钟之-数组的创建与遍历
数组作为Java中存储和操作一组相同类型数据的基本结构,其创建和遍历是编程基础中的基础。通过不同的创建方式,可以根据实际需求灵活地初始化数组。而选择合适的遍历方法,则可以提高代码的可读性和效率。掌握这些基本技能,对于深入学习Java乃至其他编程语言的数据结构和算法都是至关重要的。
20 6
|
21天前
|
存储 Java 程序员
【一步一步了解Java系列】:何为数组,何为引用类型
【一步一步了解Java系列】:何为数组,何为引用类型
20 1