顺序表和链表
创始人
2024-11-06 04:36:02

1. 线性表

定义:线性表( linear list )是n个具有相同特性的数据元素的有限序列。线性表是⼀种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串...

相同特性包括逻辑结构和物理结构。

逻辑结构:认为想象出来的一种结构。

物理结构:数据在内存中的存储形式。

线性表在逻辑上是线性结构,也就说是连续的⼀条直线。但是在物理结构上并不⼀定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。

2. 顺序表(SeqList)/(sequence:顺序的,list:列表)

2.1 概念与结构

概念:顺序表是用⼀段物理地址连续的存储单元依次存储数据元素的线性结构,⼀般情况下采用数组存储。

顺序表和数组的区别?
顺序表的底层结构是数组,对数组的封装,实现了常用的增删改查等接

对于线性表来说,逻辑结构都是线性的,物理结构不一定是线性的。

顺序表的底层结构就是数组。

 顺序表是对数组(增加、删除、修改、查找数据)来实现的,也就是对数组进行封装得到的。

2.2 分类

顺序表分为静态顺序表和动态顺序表。

2.2.1静态顺序表

概念:使用定长数组存储元素。

静态顺序表缺陷:空间给少了不够用,给多了造成空间浪费

 2.2.2 动态顺序表

2.3 动态顺序表的实现 

包括对顺序表的增删查改。

定义三个文件,如下:

其中.h结尾的头文件起着相当于目录的作用。 

动态顺序表实现的前提:

1.定义顺序表的结构

2.顺序表的初始化

3.顺序表的销毁

接下来就是对顺序表中数据的插入

顺序表数据的插入包含头插(SLPushFront)和尾插(SLPushBack),接下来先介绍尾插。

尾插包含两种情况:

1.空间充足

2.空间不足

 这时capacity表示的是空间容量(10),再插入数据后插入到size指向的位置(因为数组的下标是从0开始的),插入之后size要+1,因为size是有效数据个数。

空间不足的时候这时的capacity大小为3,再插入一个数据是肯定插不下的,这时就要对空间进行增容了(realloc),但要如何增容呢?

其实增容是成倍数的增加,比如2、3、4.....

但很多人又有疑问了,为什么不一次增加一个呢?这样不就没有空间浪费了吗?

其实增容的操作本身就有一定的性能的消耗,若频繁的增容会导致程序效率低下。

增容分两种情况:

1.连续空间足够,直接扩容

2.连续空间不够

   1)重新找一块地址,分配足够的空间

   2)拷贝数据到新的地址

   3)销毁旧地址

相关内容

热门资讯

裸辞做“一人公司”,我后悔了 去年这个时候,一位以色列程序员正在东南亚旅行。他顺手把一个在脑子里转了很久的想法做成了产品,一个让任...
南京建成国内首个Pre-6G试... 4月21日,2026全球6G技术与产业生态大会在南京开幕。全息互动技术展台前,一名远在北京的工作人员...
超梵求职受邀参加“2025抖音... 超梵求职受邀参加“2025抖音巨量引擎成人教育行业生态大会”,探讨分享优质内容传播,服务万千学员。 ...
摩托罗拉Razr 2026(R... IT之家 4 月 22 日消息,摩托罗拉宣布新一代 Razr 折叠手机将于 4 月 29 日在美国发...
库克卸任,特纳斯领航:苹果新纪... 苹果首席执行官蒂姆·库克将卸任,硬件工程主管约翰·特纳斯将接任,苹果公司今天宣布此事。 库克将在夏季...