C++ 多维数组2025年8月29日 | 阅读11分钟 多维数组在 C++ 中也称为矩形数组。它可以是二维或三维的。数据以表格形式(行-列)存储,也称为矩阵。它是同类项目的集合,其中每个元素都使用多个索引访问。 C++ 中多维数组的语法考虑一个语法来演示 C++ 中的多维数组。
示例让我们看一个简单的例子来初始化 C++ 中的多维数组。 示例编译并运行输出 5 10 0 0 15 20 30 0 10 这里,我们使用了一个整数类型的二维数组。array1 声明为 3 行 3 列,总共包含 9 个整数元素。 C++ 多维数组的大小在一维数组中,数组的大小是通过元素数量乘以每个元素的大小来计算的。对于多维 数组,添加每个维度都会影响数组的总大小,使其大小计算更加复杂。元素的总数是通过将所有维度的大小相乘来确定的,类似于二维中的面积计算和三维中的体积计算。 考虑一个例子;
代码实现 让我们看一个例子来演示 C++ 中多维数组的大小。 示例编译并运行输出 Total no of bytes: 24 C++ 中的二维数组C++ 提供了二维数组,它使用数组的数组组织方式来表示表格形式的数据,例如矩阵和表格。该结构包含通过两个索引集定义其位置的维元素。 在 C++ 中创建二维数组为了声明一个二维数组,我们可以使用以下语法在 C++ 中创建一个二维数组。 语法 它具有以下语法: data_type array_name[rows][columns];
示例: 声明二维数组 int matrix[3][3]; // 创建一个 3x3 矩阵(二维数组) 初始化二维数组二维数组可以通过不同的方式初始化 a) 声明时初始化 在此方法中,在声明时将值分配给数组元素。 结果矩阵 1 2 3 4 5 6 7 8 9 说明 此示例创建一个 3×3 矩阵并使用给定值对其进行初始化。元素按行主序存储。第一行包含 {1, 2, 3},第二行包含 {4, 5, 6},第三行包含 {7, 8, 9}。 b) 部分初始化 在此方法中,如果我们提供的元素少于所需数量,则其余元素会自动初始化为 0。 结果矩阵 1 2 0 3 4 0 5 0 0 说明 仅提供特定值,其余自动设置为 0。第一行包含 {1, 2, 0},第二行包含 {3, 4, 0},第三行包含 {5, 0, 0}。 c) 手动初始化 初始化二维数组的另一种方法是手动为单个元素赋值。 结果矩阵 1 2 ? ? ? 5 ? ? ? 说明 在这里,我们明确地将值分配给数组中的特定位置。其余位置未初始化(包含垃圾值,如果是全局/静态数组则为 0)。 遍历二维数组数组遍历表示程序员可以访问和打印数组结构中包含的所有元素的过程。 示例编译并运行输出 1 2 3 4 5 6 更新二维数组更新二维数组中的元素需要使用其索引值。 说明 arr[1][2] = 9; 更新第二行第三列的值。数组大小不变,仅值发生变化。 访问二维数组中的元素让我们看一个例子,演示如何在 C++ 中访问二维数组中的元素。 示例编译并运行输出 Accessed Element: 6 C++ 中的三维数组C++ 中的三维数组实现通过在行和列的基础上添加深度来扩展二维数组结构,从而将元素组织成多层。该变体表示三维体积数据以及多层对象和三维矩阵。 在 C++ 中创建三维数组三维数组的声明取决于三个连续的数组索引。 语法 它具有以下语法:
示例: 声明三维数组 初始化三维数组有几种初始化三维数组的方法。 a) 声明时初始化 在 C++ 中,我们可以在声明期间直接为所有元素赋值。 说明 第一层 { {1, 2}, {3, 4} } 包含两行。第二层 { {5, 6}, {7, 8} } 遵循相同的结构。 b) 部分初始化 在 C++ 中,我们可以在声明期间部分赋值给所有元素。 结果三维数组 Layer 1: 1 0 3 4 Layer 2: 5 6 7 0 c. 手动初始化 在 C++ 多维数组中,使用索引逐个赋值。 遍历三维数组遍历三维数组需要实现三个连续的循环操作。 示例 让我们看一个例子来演示如何在 C++ 中遍历三维数组。 示例编译并运行输出 1 2 3 4 5 6 7 8 9 10 11 12 更新三维数组更新一个特定元素需要同时使用三个索引。用户需要三个处理层、行和列的 循环。 示例编译并运行输出 Updated value at arr[1][0][2]: 99 说明 给定的代码定义了一个 3D 数组 arr[2][2][3],表示 2 层、2 行和 3 列。它使用预定义值初始化数组,然后将第 1 层、第 0 行、第 2 列的元素更新为 99。更新 3D 数组中的特定元素需要三个索引,并且遍历所有元素通常涉及三个嵌套 循环。 访问三维数组中的元素可以使用其特定的层、行和列索引以 'array[layer][row][column]' 格式访问三维数组中的元素。 示例编译并运行输出 Accessed Element: 12 C++ 多维数组示例:同时声明和初始化让我们看一个多维数组的简单例子,它在声明时初始化了该数组。 示例编译并运行输出 2 5 5 4 0 3 9 1 8 将多维数组传递给函数C++ 要求用户在将多维数组传递给函数时列出所有非第一个的数组维度。编译器使用此信息来计算精确的内存偏移量,从而实现元素访问。 语法 它具有以下语法: 必须指定列数,而行数可以省略。 示例:传递二维数组示例编译并运行输出 2D Array Elements: 1 2 3 4 5 6 C++ 多维数组的要点C++ 多维数组有几个重要的要点。C++ 多维数组的一些主要要点如下:
常见问题解答 (FAQs)1. C++ 中的多维数组是什么? C++ 中的多维数组包含多个维度,这使其能够以定义的表格或矩阵结构存储信息。二维数组 (2D arrays) 作为最流行的多维构造,而 C++ 支持三维 (3D)、四维 (4D) 和其他更高维数组。 2. 我们为什么要使用多维数组?
3. C++ 中多维数组的优缺点是什么? 优点
缺点
4. C++ 中如何声明二维数组? 二维数组使用以下语法声明 5. C++ 编程语言中存在哪些多维数组? C++ 多维数组的结构和内存安排允许将其分类为多个类别 二维数组
三维数组
高维数组
高阶数组主要用于高级数学计算和模拟。 下一主题C++ 中的面向对象编程概念 |
我们请求您订阅我们的新闻通讯以获取最新更新。
我们提供所有技术(如 Java 教程、Android、Java 框架)的教程和面试问题
G-13, 2nd Floor, Sec-3, Noida, UP, 201301, India