目录
二维数组
二维数组定义方式
二维数组数组名
二维数组案例:成绩统计(三行三列)
二维数组
就是在一维数组上,多加一个维度。
二维数组定义方式
1.数据类型 数组名[行数][列数];
2.数据类型 数组名[行数][列数]={ {数据1,数据2},{数据3,数据4} }; 更直观
3.数据类型 数组名[行数][列数]={ 数据1,数据2,数据3,数据4 };
4.数据类型 数组名[ ][列数]={ 数据1,数据2,数据3,数据4 };
#include <stdio.h>
#include <iostream>
using namespace std;
int main()
{
//定义方式1:数据类型 数组名[行数][列数];
int arr[2][3];
arr[0][0] = 1;
arr[0][1] = 2;
arr[0][2] = 3;
arr[1][0] = 4;
arr[1][1] = 5;
arr[1][2] = 6;
cout << arr[1][0] << endl;
//定义方式2:数组名[行数][列数]={ {数据1,数据2},{数据3,数据4} };
int arr2[2][3] = {
{10,20,30},
{40,50,60} };
//定义方式3:数组名[行数][列数]={ 数据1,数据2,数据3,数据4 };
int arr3[2][3] = { 10,20,30,40,50,60 };
//定义方式4:数组名[ ][列数]={ 数据1,数据2,数据3,数据4 };
int arr4[ ][3] = { 10,20,30,40,50,60 };
//利用循环,输出数组中的元素
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 3; j++)
{
cout << arr4[i][j] << " ";
}
cout << endl;
}
system("pause");
return 0;
}
二维数组数组名
1.查看二维数组所占内存空间
2.获取二维数组首地址
int main()
{
int arr[2][3] =
{
{10,20,30},
{40,50,60}
};
//查看占用内存空间
cout <<"二维数组占用内存空间"<<sizeof(arr) << endl;//int类型一个元素占4字节
cout <<"二维数组第一行占用内存空间" << sizeof(arr[0]) << endl;
cout << "二维数组第一行元素占用内存空间" << sizeof(arr[0][0]) << endl;
cout << "二维数组行数" << sizeof(arr) / sizeof(arr[0]) << endl;
cout << "二维数组列数" << sizeof(arr[0]) / sizeof(arr[0][0]) << endl;
//查看二维数组的首地址
cout << "二维数组首地址" << arr << endl;//十六进制
cout << "二维数组首地址" << (int)arr << endl;//十进制
cout << "二维数组第一行首地址" << (int)arr[0] << endl;
cout << "二维数组第二行首地址" << (int)arr[1] << endl;//第一行与第二行差12字节
cout << "二维数组第一个元素首地址" << (int)&arr[0][0] << endl;//具体到某个元素加&(取址符)
cout << "二维数组第二个元素首地址" << (int)&arr[0][1] << endl;//与第一个元素差4字节
system("pause");
return 0;
}
二维数组案例:成绩统计(三行三列)
语文 | 数学 | 英语 | |
张三 | 100 | 100 | 100 |
李四 | 90 | 50 | 100 |
王五 | 60 | 70 | 80 |
#include <string>
int main()
{
//创建二维数组
int scores[3][3] =
{
{100,100,100},
{90,50,100},
{60,70,80}
};
string names[3] = { "张三","李四", "王五" };
//统计每个人的总和分数
for (int i = 0; i < 3; i++)
{
int sum = 0;
for (int j = 0; j < 3; j++)
{
sum += scores[i][j];
//cout << scores[i][j] << " ";
}
cout << names[i] << "的总分" << sum << endl;
}
system("pause");
return 0;
}