线性表的实现方式有哪些
线性表的实现方式有哪些?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
创新互联一直通过网站建设和网站营销帮助企业获得更多客户资源。 以"深度挖掘,量身打造,注重实效"的一站式服务,以成都网站设计、做网站、移动互联产品、成都全网营销推广服务为核心业务。十年网站制作的经验,使用新网站建设技术,全新开发出的标准网站,不但价格便宜而且实用、灵活,特别适合中小公司网站制作。网站管理系统简单易用,维护方便,您可以完全操作网站资料,是中小公司快速网站建设的选择。
线性表有2种实现方式,分别是:1、顺序存储结构,其元素所占的存储空间是连续的且按逻辑顺序依次存放的;2、链式存储结构,是可以不连续的一组任意的存储单元,有两部分存储,一部分存放数据元素值的数据域,一部分存放直接前驱或直接后继结点的指针域。
线性表有两种基本的存储结构:顺序存储结构和链式存储结构。
1、顺序表
具有以下两个基本特点:
(1) 线性表的所有元素所占的存储空间是连续的。
(2) 线性表中各数据元素在存储空间中是按逻辑顺序依次存放的。
2、线性表的链式存储
线性表的链式存储结构就是用一组任意的存储单元(可以是不连续的)存储线性表的数据元素。
对线性表中的每一个数据元素,都需用两部分来存储:一部分用于存放数据元素值,称为数据域;另一部分用于存放直接前驱或直接后继结点的地址(指针),称为指针域,称这种存储单元为结点。
3、循环链表
循环链表(Circular Linked List)是另一种形式的链式存储结构。它将单链表中最后一个结点的指针指向链表的头结点,使整个链表头尾相接形成一个环形。
4、双向链表
双向链式是用两个指针表示结点间的逻辑关系。即增加了一个指向其直接前驱的指针域,这样形成的链表有两条不同方向的链,前驱和后继,因此称为双链表。
typedef struct DNode{ ElemType data; struct DNode *prior; struct DNode *next; }Dnode,*DuLinkList;
5、实际使用过程中的定义形式
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。
本文名称:线性表的实现方式有哪些
标题来源:http://pcwzsj.com/article/ieedjj.html