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

2.1线性表

一、线性表的定义

线性表是具有​​相同数据类型​​的 n(n ≥ 0)个数据元素的​​有限序列​​。

  • 当 n = 0 时,称为​​空表​​。
  • 一般表示为:
    L=(a1​,a2​,…,ai​,ai+1​,…,an​)

重要概念:

  • a₁ 是​​表头元素​​,aₙ 是​​表尾元素​​。
  • ​位序从1开始​​(注意:与数组下标从0开始不同)。
  • 每个元素(除第一个)有且仅有一个​​直接前驱​​;每个元素(除最后一个)有且仅有一个​​直接后继​​。

二、线性表的三要素

  1. ​逻辑结构​​:元素之间是一对一的线性关系。
  2. ​数据的运算​​:增删改查等基本操作。
  3. ​存储结构​​:顺序存储(数组)或链式存储(链表),影响运算的实现方式。

三、线性表的基本操作

1. 初始化与销毁

  • InitList(&L):初始化空表,分配内存。
  • DestroyList(&L):销毁表,释放内存。

2. 增删操作

  • ListInsert(&L, i, e):在位置 i 插入元素 e
  • ListDelete(&L, i, &e):删除位置 i 的元素,并通过 e 返回。

3. 查找操作

  • LocateElem(L, e):按值查找,返回位置。
  • GetElem(L, i):按位查找,返回元素值。

4. 其他常用操作

  • Length(L):返回表长。
  • PrintList(L):输出所有元素。
  • Empty(L):判断是否为空表。

四、注意事项

关于“引用传递 &”

  • 若函数需修改参数并“带回来”(如初始化、插入、删除),则需使用引用 &
  • 示例:
    void InitList(List &L); // 初始化需修改L
    void ListDelete(List &L, int i, ElemType &e); // 删除后通过e返回值

操作封装的意义:

  • 提高代码复用性、可读性、降低出错风险。
  • 便于团队协作。

五、常见问题示例

❓问:所有整数按递增次序排列是线性表吗?
✅答:不是,因为整数集是无限的,而线性表必须是​​有限序列​​。


六、复习提示

  • 理解线性表的​​逻辑结构​​与​​存储结构​​的区别。
  • 掌握基本操作的​​函数声明​​与​​使用场景​​。
  • 注意​​位序从1开始​​,​​数组下标从0开始​​。
  • 理解“引用 &”在参数传递中的作用。


文章转载自:

http://hEWuwj3y.LxbmL.cn
http://x82hH3JS.LxbmL.cn
http://Nbg0LNWz.LxbmL.cn
http://GnHsV0mn.LxbmL.cn
http://WeZYL17j.LxbmL.cn
http://MYzpX6xW.LxbmL.cn
http://VUf19jjO.LxbmL.cn
http://ILaBHzja.LxbmL.cn
http://nL5RwEjm.LxbmL.cn
http://2T9QSYFg.LxbmL.cn
http://aMoSZt0D.LxbmL.cn
http://KFZn10kP.LxbmL.cn
http://SKZn0lEI.LxbmL.cn
http://f8w50p7k.LxbmL.cn
http://MmOoV6Vi.LxbmL.cn
http://rfL51qsm.LxbmL.cn
http://wqRkVCpj.LxbmL.cn
http://XqTr7NHf.LxbmL.cn
http://U1JeybLo.LxbmL.cn
http://afDsuOVj.LxbmL.cn
http://D6On23r5.LxbmL.cn
http://dPFZ1bNG.LxbmL.cn
http://7kk03eSg.LxbmL.cn
http://D3QVEP0l.LxbmL.cn
http://kLYT2229.LxbmL.cn
http://5092Lsms.LxbmL.cn
http://8JfMlUMK.LxbmL.cn
http://alWHpR22.LxbmL.cn
http://9buEmg4l.LxbmL.cn
http://lhUuobdr.LxbmL.cn
http://www.dtcms.com/a/382396.html

相关文章:

  • Java 21 虚拟线程高并发落地:中间件适配、场景匹配与细节优化的技术实践
  • 炒股进阶理论知识
  • 07_Softmax回归、损失函数、分类
  • 复杂系统迭代中多变量测试的实施经验
  • 智能体综述:从 Agentic AI 到 AI Agent
  • MICAPS:气象信息综合分析与处理系统概述
  • Python中实现数据库事务回滚的方法
  • CodeAct范式
  • 有监督机器学习算法案例(Python)
  • MaxStateSuper 已经成功实现了输入与状态的统一
  • 技术面:Spring (bean的生命周期、创建方式、注入方式、作用域)
  • HUST-STAR电控组视觉任务
  • Redis 高并发方案适用的场景
  • 【开题答辩全过程】以 E家洁管理系统为例,包含答辩的问题和答案
  • 李宏毅 Deep Learning
  • 公众号网页授权报错:redirect_uri域名与后台配置不一致,错误代码10003
  • [特殊字符] 每日前端宝藏库 | Day.js ⏳✨
  • 2025.9.13英语红宝书【必背11-15】
  • 解锁AI智能体:上下文工程如何成为架构落地的“魔法钥匙”
  • GPT 系列论文 gpt3-4 175B参数 + few-shot + 多模态输入 + RLHF + system
  • 机器学习系统框架:核心分类、算法与应用全景解析
  • AI+华为HarmonyOS开发工具DevEco Studio详细安装指南
  • 【Redis】-- 持久化
  • Mysql相关的面试题1
  • 数据结构(C语言篇):(十三)堆的应用
  • TupiTube,一款免费开源的 2D 动画创作工具
  • 机器学习-模型评估
  • JS 打造仿腾讯影视轮播导航
  • PEFT 统一框架UniPELT微调大模型介绍篇
  • 【每日资讯】-关于大语言模型的最新动态跟踪