04.01 数组

本文介绍了数组,特别是二维数组的概念,将其视为线性表的组合。详细阐述了数组的顺序存储结构,以二维数组为例,讨论了按行序和列序存储的方式,并提供了计算特定元素存储位置的公式。内容涵盖了数组的存储原理及其在C语言和Java中的实现细节。
摘要由CSDN通过智能技术生成

一:数组

<1>知识点概述

数组是由相同类型的数据元素构成的有限集合。一维数组可以看作一个线性表。

在这里插入图片描述

二维数组也可以看作一个线性表X=(X0,X1,X2,…,Xn-1),只不过每一个数据元素Xi也是一个线性表。

在这里插入图片描述

横看成岭侧成峰,二维数组也可以看作一个线性表Y=(Y0,Y1,Y2,…,Ym-1),只不过每一个数据元素Yi也是一个线性表。

在这里插入图片描述

<2>数组存储

数组一般采用顺序存储结构,因为存储单元是一维的,而数组可以是多维,如何用一组连续的存储单元来存储多维数组呢?以二维数组为例,可以按行序存储,即先存第一行,再存第二行,…;也可以按列序存储,先存第一列,再存第二列,…;现在比较流行的C语言,Java都是按行序存储的。

如果按行序存储,怎么找到aij的存储位置呢?
先看看存储aij之前,前面已经存储了多少个元素。

在这里插入图片描述

在aij之前一共有in+j个元素,如果每个元素占用L个字节,那么共需要(in+j)*L个字节,只需要用基地址加上这些字节就可以得到aij的存储地址了。

在这里插入图片描述

如果按列序存储,怎么找到aij的存储位置呢?
先看看存储aij之前,前面已经存储了多少个元素。

在这里插入图片描述

在aij之前一共有jm+i个元素,如果每个元素占用L个字节,那么共需要(jm+i)*L个字节,只需要用基地址加上这些字节就可以得到aij的存储地址了。

在这里插入图片描述

特别注意:二维数组的下标是从1开始的,那么画风就变了~~~
先看看存储aij之前,前面已经存储了多少个元素。

在这里插入图片描述

行数和个数都少1,在aij之前一共有(i-1)*n+j-1个元素,如果每个元素占用L个字节,那么共需要((i-1)*n+j-1)*L个字节,只需要用基地址加上这些字节就可以得到aij的存储地址了。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值