关于数据结构中线性表和链表简要概述

编程常涉及数据结构,线性表和链表是其中最基本类型。线性表以线性关系存储,内存地址多连续,查找快但插入删除慢,还易造成资源浪费;链表采用链式存储,内存地址不连续,查找慢但插入删除快,无需提前申请内存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

编程离不开数据结构,而线性表和链表是数据结构中最基本的两种类型,下面介绍一下线性表和链表的一些特性

1.线性表

存储方式:顾名思义,线性表就是以线性关系进行存储的表,也可以说是顺序表,其空间的内存地址一般而言都是连续的
时间复杂度:查找:O(1)     插入和删除:O(n)
空间复杂度:需要提前申请足够的内存单元,一般都会申请更大一些空间,容易造成资源浪费

2.链表

存储方式:采用链式存储结构,用一组任意的存储单元存放线性表的元素,内存地址一般不连续
时间复杂度:查找:O(n)    插入和删除:O(1)
空间复杂度:无需提前申请内存单元,随用随时分配

单纯文字来看,可能不太好理解,so个人找了几张比较形象的图片来帮助大家理解(图片来自百度图片)

线性表:
简简单单明明白白的顺序存储结构,数据所在的内存地址都是连续的(也有头部和数据存储空间不连续通过指针指向连接的,但是数据的内存地址依然是连续的)
在这里插入图片描述
链表:
head头为一个指针和一个空的内存单元组成,其作用只是用来指向第一组的内存地址,每组存储单元由两部分组成,头部为指向下一组的指针,尾部为数据(这里头尾说法不是很严谨,大家理解就好),因此进行插入删除操作时只需改变与其相关的组的指针指向就行
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值