Homework Introduction
二维数组的定义
当一维数组元素的类型也是一维数组时,便构成了数组的数组,即二维数组。
二维数组定义的一般格式:
数据类型 数组名[常量表达式1] [常量表达式2] ;
例如:int a[4][10];
a 数组实质上是一个有 4 行、10 列的表格,表格中可储存 40 个元素。第 1 行第 1 列对应 a 数组的 a[0][0]
,第 n 行第 m 列对应数组元素 。
多维数组
多维数组定义的一般格式: 数据类型 数组名[常量表达式1] [常量表达式2] .... [常量表达式n];
如定义一个三维数组 a 和四维数组 b:
int a[100][3][5];
int b[100][100][3][5];
多维的数组访问赋值等操作与二维数组类似。
二维数组的访问
二维数组的数组元素访问与一维数组元素访问类似,区别在于二维数组元素的访问必须给出两个下标。 访问的格式为:
数组名[下标1][下标2]
说明:显然,每个下标表达式取值不应超出下标所指定的范围,否则会导致致命的越界错误。
例如,设有定义:int a[3][5];
则表示 a 是二维数组(相当于一个 3*5
的表格),共有 3*5=15
个元素,它们是: a[0][0] a[0][1] a[0][2] a[0][3] a[0][4] a[1][0] a[1][1] a[1][2] a[1][3] a[1][4] a[2][0] a[2][1] a[2][2] a[2][3] a[2][4]
因此可以看成一个矩阵(表格),a[2][3]
即表示第 3 行第 4 列的元素。
#include <iostream>
#include <cstdio>
using namespace std;
int a[2][3] = {
{123, 2, 3},
{4, 5, 6}
};
int main(){
cout << a << " " << *(*a) << endl;
printf("%p %d\n", &a[0][0], a[0][0]);
printf("%p %d\n", &a[0][1], a[0][1]);
printf("%p %d\n", &a[0][2], a[0][2]);
printf("%p %d\n", &a[1][0], a[1][0]);
printf("%p %d\n", &a[1][1], a[1][1]);
printf("%p %d\n", &a[1][2], a[1][2]);
cout << a[0][5] << endl;
/*
A. 0
B. 6
C. 越界,可能引发程序异常
*/
return 0;
}
二维数组索引逻辑结构是二维,而实际上依然是一维的,因为内存结构就是一维。
二维数组输入输出样例
例如:输入 n 行,m 列 数组,然后输出数组:
#include <iostream>
using namespace std;
const int N = 110; // 一般设置为比最大题目要求多10
int n, m;
int a[N][N];
int main() {
cin >> n >> m;
for(int i = 1; i <= n; i++) // 枚举行
for(int j = 1; j <= m; j++) // 枚举列
cin >> a[i][j];
for(int i = 1; i <= n; i++){
for(int j = 1; j <= m; j++)
cout << a[i][j] << " ";
cout << endl;
}
return 0;
}
输入:
2 3
1 2 3
4 5 6
输出:
1 2 3
4 5 6
Problem
- Status
- Live...
- Problem
- 5
- Open Since
- 2024-2-9 0:00
- Deadline
- 2036-8-23 23:59
- Extension
- 24 hour(s)