当前位置: 首页 > news >正文

数据结构与算法—顺序表和链表(1)

数据结构与算法—顺序表(1)

  • 线性表
  • 顺序表
    • 概念与结构
    • 分类
      • 静态顺序表
      • 动态顺序表
    • 动态顺序表的实现

线性表

线性表(linear list)是n个具有相同特性的数据元素的有限序列。线性表是⼀种在实际中⼴泛使⽤的数据结构,常⻅的线性表:顺序表、链表、栈、队列、字符串…线性表在逻辑上是线性结构,也就说是连续的⼀条直线。但是在物理结构上并不⼀定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。

 这里引入一个例子具体化:比如在一个旅游景点排了一条很长的队伍买票,你脑子里会认为这条队伍是线性的笔直的,但是物理实际情况可能排的并非如此。

顺序表

概念与结构

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

但是顺序表和数组真的一样吗?又或者有什么关系?

其实他们的关系可以类比成两道一模一样的菜品,但是数组是在小餐馆的菜,而顺序表是星级饭馆里的菜,为什么这么说?

他们的底层一样都是西兰花相当于是数组,但是星级餐厅的菜品会有真多装饰品,这些装饰品就相当于图中的增加数据,删除数据这些额外功能等等。这就是他们的关系和区别。
在这里插入图片描述

分类

静态顺序表 和 动态顺序表

静态顺序表

使用定长的数组储存元素 缺陷:空间确定,容易造成不足或者浪费

动态顺序表

底层数组空间在不断的变化,能够根据需求来增大或者缩小,避免造成空间的短缺或者浪费

动态顺序表的实现

尾插法插入数据

头文件

在这里插入图片描述

实现文件

在这里插入图片描述

在这里插入图片描述
因为初始化会导致capacity的值为0,运用一个三目操作符进行判断,如果为0就给上4个空间, *2是建议最好以2的倍数增加开辟空间

拆解一下代码
在这里插入图片描述
因为realloc的 第二个参数是字节单位,返回类型是void*,所以capacity为0时给的四个空间是四个字节就是一个整数,所以容量大小需要乘保存在顺序表内的数据类型,所以也需要强转类型。
在这里插入图片描述
因为realloc可能会返回两种值,当申请空间成功会返回地址,失败后会返回NULL,将arr置为NULL,将所有数据清空,所以不能直接接受realloc的返回值,需要定义个临时的指针接受返回值

成功就让arr指向tmp的空间,capacity指向增加容量的空间newCapacity

测试文件

在这里插入图片描述
这就是一个动态顺序表的实现!

相关文章:

  • 互联网大厂Java求职面试:基于RAG的智能问答系统设计与实现
  • N6715C 基础型定制配置直流电源分析仪
  • 升级 Azure Kubernetes 服务群集的关键注意事项
  • C#学习——继承、封装、多态
  • 软件工程之面向对象分析深度解析
  • 《软件项目经济性论证报告模板:全面解析与策略建议》
  • 排序算法-希尔排序
  • 移动IP与手机移动数据流量的概念、原理、区别与联系
  • 手写 vue 源码 === ref 实现
  • 开源数字人框架 AWESOME-DIGITAL-HUMAN 技术解析与应用指南
  • OpenHarmony平台驱动开发(十),MMC
  • 【优选算法】C++双指针问题
  • 基于扩展卡尔曼滤波(EKF)目标轨迹算法仿真实例
  • 《深挖Java中的对象生命周期与垃圾回收机制》
  • PECVD 和 半导体等离子体刻蚀 工艺的异同点
  • 【Pandas】pandas DataFrame all
  • Java中关于多态的总结
  • 【Python-Day 11】列表入门:Python 中最灵活的数据容器 (创建、索引、切片)
  • 已解决:安卓刚打开新项目的时候,会下载该项目要求的sdk gradle,开了科学上网也慢
  • 《Spring Boot 3.0全新特性详解与实战案例》
  • 明查|哈佛大学批改美教育部长来信,红笔标出语法错误?
  • 央行最新报告:积极落地5月推出的一揽子金融政策,促进经济供需平衡、物价合理回升
  • 中国天主教组织发贺电对新教皇当选表示祝贺
  • 马克思主义理论研究教学名师系列访谈|董雅华:让学生感知马克思主义理论存在于社会生活中
  • 专访|高圆圆:像鸟儿一样,柔弱也自由
  • “半世纪来对无争议边界最深入袭击”:印巴冲突何以至此又如何收场?