前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >顺序表和链表

顺序表和链表

作者头像
用户11290648
发布2024-09-25 13:56:56
390
发布2024-09-25 13:56:56
举报
文章被收录于专栏:学习

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)销毁旧地址

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-09-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 线性表
  • 2. 顺序表(SeqList)/(sequence:顺序的,list:列表)
    • 2.1 概念与结构
      • 2.2 分类
        • 2.2.1静态顺序表
          •  2.2.2 动态顺序表
            • 2.3 动态顺序表的实现 
            相关产品与服务
            对象存储
            对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档