清华大学严蔚敏教授详解广义表的存储结构特点

需积分: 10 4 下载量 183 浏览量 更新于2024-08-21 收藏 3.3MB PPT 举报
在《数据结构(C语言版)》这本书中,关于广义表的存储结构有以下几点重要的特点: 1. 空表与指针定义:广义表为空时,表头指针hp为空;否则,表头指针始终指向一个表结点,这个结点可能是个原子结点(存储的是基本数据类型),也可能指向另一个表结点。表头结点不仅包含数据,还可能指向表尾tp,表尾是一个指示列表是否结束的标志。当表尾为空时,tp为NULL。 2. 操作便利性:这种存储结构设计使得求取广义表的长度(通过遍历直至找到表尾)、深度(从表头到最深的表结点的距离)以及访问表头和表尾都非常方便。这在编写处理广义表的程序时,能够提升代码的简洁性和效率。 3. 空间效率:然而,表结点过多可能导致空间浪费,特别是在存储大量浅层的广义表时。为了避免这种情况,可以采用更高效的链表结构,如图5-15所示,通过每个结点包含表头指针hp和表尾指针tp来节省空间。 4. 数据结构课程的重要性:数据结构是计算机科学中的核心课程,它研究如何有效地组织和存储数据,以支持各种信息处理任务。它涉及到信息的表示和处理,是程序设计和系统开发的基础。例如,电话号码查询系统和磁盘目录文件系统就是数据结构的实际应用,它们都展示了数据之间的线性关系和层次结构。 5. 数据结构的通用性:数据结构不仅应用于编程,还是编译器、操作系统、数据库系统等高级软件设计的关键组成部分。理解并掌握数据结构,能帮助程序员编写高效、可维护的代码,并确保程序性能良好。 对于广义表的存储结构,我们不仅要关注其基本的指针定义和操作便利性,还要考虑在实际问题中的优化策略,以提高存储效率。同时,数据结构的学习对整个IT行业的发展具有深远影响,是每位程序员必备的技能之一。