C语言:二维数组

1. 二维数组的定义

类型名 数组名[常量表达式][常量表达式]

如:int a[3][4];

数组a中含有的元素有:a[0][0], a[0][1], a[0][2], a[0][3],a[1][0], a[1][1], a[1][2], a[1][3], a[2][0], a[2][1], a[2][2], a[2][3]。

2. 二维数组的存储结构

二维数组中的下标变量在内存中的实际存储结构是线性的,不是二维的。想象成有行有列的二维表格形式,只是它们之间的逻辑关系。

以int a[3][4]为例,各个下标变量排列的先后顺序是:先是a[0]的四个变量,再是a[1]的四个变量,最后是a[2]的四个变量。

3.二维数组中下标变量的表示方法

下标法:如a[1][2],表示的是a[1]这个一维数组中的第二个元素。

指针法:如*(*(a+1)+2)。a[1][2]相当于是(a[1])[2],由于x[2]与*(x+2)等价,所以(a[1])[2]与*(a[1]+2)等价,这时候再把a[1]换成*(a+1),就可以得到*(*(a+1)+2)。

混合法:如*(a[1]+2),*(a+1)[2]。

4. 二维数组的引用

(1)二维数组中的下标变量在表示时,要么有两个*,要么有两对[],有么有一个*和一个[]。*和[]都用来降维,当维数降为0时,就是变量。

(2)每次只能使用数组中的一个下标变量,若要操作多个下标变量,需要分多次进行操作。

cpp 复制代码
int a[2][3],i,j;
for(i=0;i<=1;i++)
    for(j=0;j<=2;j++)
    a[i][j]=0;

5. 二维数组的初始化

(1)给所有下标变量赋初值

cpp 复制代码
int a[2][3]={1,2,3,4,5,6};

(2)可以给每行数据再加一对大括号

cpp 复制代码
int a[2][3]={{1,2,3},{4,5,6}};

(3)可以省略第一个[ ]中的表达式,省略时,编译器自动填上。

cpp 复制代码
int a[][3]={1,2,3,4};    //相当于int a[2][3];
int a[][3]={{1,2},{3},{4}};    //相当于int a[3][3];

(4)可以只对部分下标变量赋初值

cpp 复制代码
int a[2][3]={1,2,3};    //下标变量的值依次为1,2,3,0,0,0
int a[][3]={{1,2},{1}};    //下标变量的值依次为1,2,0,1,0,0
相关推荐
Evand J1 小时前
【MATLAB例程】【空地协同】UAV辅助的UGV协同定位,无人机辅助地面无人车定位,带滤波,附MATLAB代码下载链接
开发语言·matlab·无人机·无人车·uav·协同定位·ugv
chao1898441 小时前
基于MATLAB实现多变量高斯过程回归(GPR)
开发语言·matlab·回归
ytttr8736 小时前
隐马尔可夫模型(HMM)MATLAB实现范例
开发语言·算法·matlab
天远Date Lab6 小时前
Python实战:对接天远数据手机号码归属地API,实现精准用户分群与本地化运营
大数据·开发语言·python
listhi5206 小时前
基于Gabor纹理特征与K-means聚类的图像分割(Matlab实现)
开发语言·matlab
qq_433776427 小时前
【无标题】
开发语言·php
点云SLAM7 小时前
凸优化(Convex Optimization)理论(1)
人工智能·算法·slam·数学原理·凸优化·数值优化理论·机器人应用
Davina_yu7 小时前
Windows 下升级 R 语言至最新版
开发语言·windows·r语言
阿珊和她的猫8 小时前
IIFE:JavaScript 中的立即调用函数表达式
开发语言·javascript·状态模式
jz_ddk8 小时前
[学习] 卫星导航的码相位与载波相位计算
学习·算法·gps·gnss·北斗