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

数据结构之【顺序表简介】

1.顺序表的概念

顺序表 是 用一段物理地址连续的存储单元 依次 存储数据元素的线性结构

一般情况下采用数组存储

2.顺序表的结构

 既然顺序表可以用来存储数据元素

那就少不了   增删查改  的操作

此时,单一地只创建数组满足不了上述操作

创建相应的结构体变量可以很好地解决这个问题

2.1重命名数据类型名称

typedef int SLDataType;

 重命名一下数据类型的名称

这样

之后改变数据类型的时候只需要修改一处

SL是Seqlist,即顺序表的英文缩写

DataType 是数据类型的英文缩写

2.2静态顺序表

所谓静态:使用定长数组存储数据

#define N 5

typedef struct SeqList
{
	SLDataType arr[N];  //定长数组
	int size;   //有效数据个数
}SL;

 

如上图:

定义的结构体包含

一个定长数组和一个变量

数组用来存储数据,

变量用来存储有效数据的个数

很显然,

静态顺序表存在很大的缺陷,

因为

不能根据需要合理定义数组的大小

开100个单元存不下101个数据

开1万个单元存不下1万零1个数据

开10万个单元如果只存10个数据,又会浪费空间

所以我们更多的选择使用动态顺序表

按需申请空间

2.3动态顺序表

typedef struct SeqList
{
	//该指针指向所申请的空间首地址
	SLDataType* arr; 
	int size;       //有效数据个数
	int capacity;   //空间容量
}SL;

如上图:

定义的结构体中,

arr 指向动态开辟的内存空间

size 存储有效数据个数

capacity 表示空间容量,空间不够就扩容

http://www.dtcms.com/a/31331.html

相关文章:

  • Innovus中快速获取timing path逻辑深度的golden脚本
  • http+nginx
  • Compose 常用UI组件
  • Duplicate entry for key ‘PRIMARY‘ 主键重复报错解决
  • 动态规划
  • Image Downloader下载文章图片的WordPress插件
  • Redis 限流
  • unity获取指定麦克风的分贝(deepseek)
  • DeepSeek 点燃关键技术突破的科技引擎,驶向未来新航道
  • 下拉框的数据置为危险的‘删除‘状态时弹窗确认
  • Jenkins 给任务分配 节点(Node)、设置工作空间目录
  • 2025最新高维多目标优化:基于城市场景下无人机三维路径规划的导航变量的多目标粒子群优化算法(NMOPSO),MATLAB代码
  • 自动化合约生成与管理:AI与Python的完美结合
  • 阿里云通过docker安装skywalking及elasticsearch操作流程
  • `AdminAdminDTO` 和 `userSession` 对象中的字段对应起来的表格
  • 使用最广泛的Web应用架构
  • linux中的查用命令
  • 万字长文解析:深入理解服务端渲染(SSR)架构与全栈实践指南
  • 基于 JavaWeb 的 Spring Boot 网上商城系统设计和实现(源码+文档+部署讲解)
  • [深度学习][python]yolov12+bytetrack+pyqt5实现目标追踪
  • springboot整合 xxl-job
  • Transformer解析——(五)代码解析及拓展
  • Spark 性能优化(四):Cache
  • 【含文档+PPT+源码】基于Django的新闻推荐系统的设计与实现
  • 【Python爬虫(36)】深挖多进程爬虫性能优化:从通信到负载均衡
  • RPA-实例(UiPath )
  • 一文讲解Redis的持久化方式及各自的区别
  • 飞书API
  • 精准测量PMD:OCI-V光矢量分析系统赋能光纤通信性能优化
  • Angular 中获取 DOM 节点的几种方法