二维数组的应用场景
比如我们开发一个五子棋游戏,棋盘就是需要二维数组来表示。如图
二维数组的使用
快速入门案例: 请用二维数组输出如下图形
0 0 0 0 0 0
0 0 1 0 0 0
0 2 0 3 0 0
0 0 0 0 0 0
使用方式 1:
先定义在初始化 语法: 类型 数组名[大小][大小]; 比如: int a[2][3];
使用演示
二维数组在内存的存在形式,各个元素的地址是连续分布的,即在前一个元素基础上+4
代码演示:
#include <stdio.h>
void main() {
//a[4][6] : 表示一个 4 行 6 列的二维数组
int a[4][6]; // 没有初始化,则是分配的内存垃圾值
int i, j; //全部初始化 0
for(i = 0; i < 4; i++) { //先遍历行
for(j = 0; j < 6; j++) {//遍历列
a[i][j] = 0;
}
}
a[1][2] = 1;
a[2][1] = 2;
a[2][3] = 3; //输出二维数组
for(i = 0; i < 4; i++) {
for(j = 0; j < 6; j++) {
printf("%d ", a[i][j]);
}
printf("\n");
}
//看看二维数组的内存布局
printf("\n 二维数组 a 的首地址=%p", a);
printf("\n 二维数组 a[0]的地址=%p", a[0]);
printf("\n 二维数组 a[0][0]的地址=%p", &a[0][0]);
printf("\n 二维数组 a[0][1]的地址=%p", &a[0][1]); //将二维数组的各个元素得地址输出
printf("\n");
for(i = 0; i < 4; i++) {
printf("a[%d]的地址=%p ", i, a[i]);
for(j=0; j < 6; j++) {
printf("a[%d][%d]的地址=%p ", i, j , &a[i][j]);
}
printf("\n");
}
}
使用方式 2:
直接初始化
1)定义 类型 数组名[大小][大小] = {{值 1,值 2…},{值 1,值 2…},{值 1,值 2…}};
2)或者 类型 数组名[大小][大小] = { 值 1,值 2,值 3,值 4,值 5,值 6 …};
int a[4][6] = {
{0,0,0,0,0,0},
{0,0,1,0,0,0},
{0,0,1,0,0,0},
{0,2,0,3,0,0},
{0,0,0,0,0,0},
};
int a[4][6] = {0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,2,0,3,0,0,0,0,0,0,0,0};
二维数组的应用案例
请使用灵活的方式遍历如下数组 : int map[3][3] = {{0,0,1},{1,1,1},{1,1,3}};
并得到和
#include<stdio.h>
void main(){
//请使用灵活的方式遍历如下数组 : int map[3][3] = {{0,0,1},{1,1,1},{1,1,3},{2,2,6}}; 并得到和
int map[4][3] = {{0,0,1},{1,1,1},{1,1,3},{2,2,6}}; //四行三列 48
//得到行的个数
//1. sizeof(map) 得到这个 map 数组的大小 12 * 4 = 48
//2. sizeof(map[0]) 得到 map 中,第一行有多大 3 * 4 = 12
int rowarrLen = sizeof(map) / sizeof(map[0]); //4
printf("行的个数=%d",rowarrLen);
//得到列的个数
int colarrLen = sizeof(map[0]) / sizeof(int); //3
printf("\n列的个数=%d\n",colarrLen);
int i,j;
int sum = 0;
//遍历
for(i = 0; i < rowarrLen;i++){
for(j = 0;j < colarrLen; j++){
printf("%d ",map[i][j]);
sum = sum + map[i][j];
}
printf("\n");
}
printf("sum=%d",sum);
}
定义二维数组,用于保存三个班,每个班五名同学成绩,并求出每个班级平均分、 以及所有班级平均分。
#include<stdio.h>
void main() {
//定义二维数组,用于保存三个班,每个班五名同学成绩,并求出每个班级平均分、 以及所有班级平均分。
//定义数组
double arr[3][5];
//行个数
int row = sizeof(arr) / sizeof(arr[0]);
//列个数
int col = sizeof(arr[0]) / sizeof(double);
//定义i j
int i,j;
//定义学生总成绩,班级总成绩
double totalScore = 0.0, classTotalScore = 0.0;
//初始化数组
for(i = 0; i<row; i++) {
for(j = 0; j<col; j++) {
arr[i][j];//初始化
}
}
//printf("%lf",arr[0][0]);
//给每个学生输入成绩
for(i = 0; i<row; i++) {
for(j = 0; j<col; j++) {
printf("请输入第 %d 班的第 %d 个学生的成绩:",i+1,j+1);
scanf("%lf",&arr[i][j]);
}
}
//显示成绩情况
for(i = 0; i<row; i++) {
for(j = 0; j<col; j++) {
arr[i][j];//初始化
printf("%.2f ",arr[i][j]);
}
printf("\n");
}
//统计分数
for(i = 0; i<row; i++) {
//每一个循环之后,班级的成绩清零
classTotalScore = 0.0;
for(j = 0; j<col; j++) {
classTotalScore = classTotalScore + arr[i][j];
}
printf("\n第 %d 个班的平均成绩是 %.2f" , i+1, classTotalScore/col);
totalScore += classTotalScore; //将该班级的总分,累计到 totalScore
}
printf("\n所有学生总成绩是 %.2f 平均成绩 %.2f" , totalScore, totalScore/(row * col));
getchar();
}
二维数组使用细节和注意事项
1)可以只对部分元素赋值,未赋值的元素自动取“零”值【案例】
#include<stdio.h>
int main(){
int a[4][5] = {{1}, {2}, {3},{1}};
int i,j;
for (i = 0; i < 4; i++ ) {
for (j = 0; j < 5 ; j++ ) {
printf("%d ",a[i][j]);
}
printf("\n");
}
}
2) 如果对全部元素赋值,那么第一维的长度可以不给出。比如:
int a[3][3] = {1, 2, 3, 4, 5, 6, 7, 8, 9};
可以写为:
int a[][3] = {1, 2, 3, 4, 5, 6, 7, 8, 9};
但不可以写成:
int a[3][0] = {1, 2, 3, 4, 5, 6, 7, 8, 9};
这是不可取的
3)二维数组可以看作是由一维数组嵌套而成的;如果一个数组的每个元素又是一个数组,那么它就是二维数组。
二维数组 a[3][4]可看成三个一维数组,它们的数组名分别为 a[0]、a[1]、a[2]。
这三个一维数组都有 4 个元素,
如,一维数组 a[0] 的元素为 a[0][0]、a[0][1]、a[0][2]、a[0][3]