定义和引用二维数组
具有两个下标的数组称为二维数组。
定义二维数组
定义二维数组的一般形式为
类型名 数组名[常量表达式][常量表达式]
C++中二维数组中元素排列的顺序是:按行存放。即在内存单元中先顺序存放第一行的元素,再存放第二行元素。
C++允许使用多维数组。
引用二维数组的元素
引用二维数组的元素的一般形式为
数组名 [下标][下标]
数组元素是左值,可以出现在表达式中,也可以被赋值。
在使用数组元素时,应注意下标值应在已定义的数组大小的范围内。
二维数组的初始化
可以用下面的方法对二维数组进行初始化
1、按行给二维数组全部元素赋初值,这种方法比较直观。如:
a[3][4]={{1,2,3,4},{2,2,3,4},{3,2,3,4},{4,2,3,4}};
2、可以将所有数据写在一个花括号内,按数组排列的顺序对全部元素赋初值。效果与第一种方法相同,但容易遗漏,也不好检查。如:
a[3][4]={1,2,3,4,2,2,3,4,3,2,3,4,4,2,3,4};
3、可以对部分元素赋初值,未赋值的元素自动置为0。如:
a[3][4]={{1},{2},{3}};
4、如果对全部元素都赋初值,则定义数组时,对第一维的长度可以不指定,但第二维的长度不能省略,系统会根据总个数分配存储空间。如:
a[][4]={1,2,3,4,5,6,7,8,9,10,11,12};
例1:将一个2*3的二维数组a的行和列元素互换,存到一个3*2的二维数组b中。
#include <iostream>
using namespace std;
int main()
{
int a[2][3] = { {1,2,3},{4,5,6} };
int b[3][2], i, j;
cout << "数组a中数据:" <<endl;
for (i = 0; i <= 1; i++)
{
for (j = 0; j <= 2; j++)
{
cout << a[i][j] << " ";
b[j][i] = a[i][j];
}
cout << endl;
}
cout << "数组b中数据:" << endl;
for (j = 0; j <= 2; j++)
{
for (i = 0; i <= 1; i++)
cout << b[j][i] << " ";
cout << endl;
}
return 0;
}
结果如下:

例2:有一个3*4的矩阵,要求编写程序求出其中值最大的那个元素,以及其所在的行号和列号。
#include <iostream>
using namespace std;
int main()
{
int a[3][4] = { 11111,23,45645,7,-8910,11,-12,147,258,369,12365,-5 };
int i, j, row = 0, colum = 0, max;
max = a[0][0];
for (i = 0; i <= 2; i++)
for (j = 0; j <= 3; j++)
if (max < a[i][j])
{
max = a[i][j];
row = i;
colum = j;
}
cout << "矩阵中最大值为:" << max << "。为第 " << row << " 行," << "第 " << colum << " 列!";
return 0;
}
//结果为:矩阵中最大值为:45645。为第 0 行,第 2 列!
C++二维数组的定义、引用与初始化

被折叠的 条评论
为什么被折叠?



