C语言实现顺序表的存储

今天我们来讲一下线性表当中最基本一种数据结构—线性表的顺序存储。

今天我们要讲的线性表它的大体框架跟C语言当中的数组很像,可以这样说数组是特殊的线性表。

可以这样说线性表是一个数组,数组的每一个元素又是一个新的数组,听起来有点像在套娃,但真实的情况就是这样。

下面就是图书表的一个顺序存储结构的示意图:

可以看出数组elem当中的每一个元素都是另一个数组,这个数组有三个元素分别包含书的编码,书名,价格。

顺序表很好理解,下面我们来看一下如何用C语言来实现线性表用来存储班级中每一个同学的成绩的一些基础操作。

首先要定义线性表我们要用到C语言当中的struct来定义。

学生结构体:

成绩单结构体:

我们首先要对顺序表进行初始化:

实现对成绩单插入一个学生的成绩我们这里每一次插入都是从length位置插入:

实现删除时要注意数组的删除之后要将删除位置后面的每一个元素的往前移一位,最后还应将记录学生个数length减一

我们经常要想去查找某一个同学的成绩,下面的代码来实现查找一位同学成绩的功能:

当某一位同学的成绩出现错误我们要找到这位同学的成绩在成绩单当中的位置,然后将这位同学的成绩修改:

以上就是顺序表的增删改查操作的C语言的代码实现,里面用到了C语言当中的结构体以及指针相关的知识。

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

带点脑子~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值