数据结构 数组与广义表.pptVIP

  1. 1、本文档共46页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
十字链表表示的稀疏矩阵举例 i j e down right 结点结构: 稀疏矩阵M: M的十字链表: M.chead M.rhead 1 1 3 1 4 5 ^ ^ 2 2 -1 ^ ^ ^ ^ 3 1 2 采用十字链表存储稀疏矩阵,创建稀疏矩阵、稀疏矩阵的运算见教材P104-106 * 5.3 广义表 (General Lists ) 广义表(列表):n (?0)个表元素组成的有限序列,记作 LS = (a1, a2, …, an) 表头(head):n0时,表的第一个表元素 表尾(tail):其它表元素组成的表 空表:n = 0 的广义表。 广义表的特性: 有长度:n 有深度:广义表中括号的重数 可递归 可共享 表名 表元素 表长 非空列表表头可是原子或列表,表尾必定是列表 * 广义表的图形表示 1、A=(/) 2、B=(e) 3、C=(a,(b,c,d)) 4、D=(A,B,C) 注: ○:表 □:原子 * 5.3.1广义表的定义 GetHead(L):在广义表L存在的条件下,取L的表头。 GetTail(L):在广义表L存在的条件下,取L的表尾。 举例: 1 A=()    GetHead(A)=NULL,GetTail(A)=NULL 2 B=(e)    GetHead(B)=e, GetTail(B)=() 3 C=(a,(b,c,d)) GetHead(C)=a, GetTail(C)=(b,c,d) GetHead((b,c,d))=b, GetTail((b,c,d))=(c,d) GetHead((c,d))=c, GetTail((c,d))=(d) 4 D=(A,B,C) GetHead(D)=A, GetTail(D)=(B,C)     GetHead((B,C))=B, GetTail((B,C))=(C) 5 E=(())   GetHead(B)=(), GetTail(B)=() * 5.3.2 广义表的存储结构 采用链式存储结构,元素包括原子和子表,结点结构: 表结点: 表示列表 原子结点: 表示原子 1、广义表的头尾链表存储表示: typedef enum {ATOM,LIST}ElemTag;//ATOM=0:原子,LIST=1:子表 typedef struct GLNode{ ElemTag tag;//公共部分,用来区分原子结点和表结点 Union{//原子结点和表结点的联合部分 AtomType atom; Struct{struct GLNode *hp,*tp;}ptr;//hp指向表头,tp指向表尾 }; }*Glist; tag=1 hp tp tag=0 atom * A=(/) B=(e) C=(a,(b,c,d)) D=(A,B,C) E=(a,E) 5.5 广义表的存储结构示例 B 0 e 1 ^ C 1 1 ^ 0 a 1 1 1 ^ 0 b 0 d 0 c D 1 ^ 1 1 ^ E 1 1 ^ 0 a A=NIL 表结点: 原子结点: tag=1 hp tp tag=0 atom * 5.5 广义表的存储结构示例 对广义表:C = (a,(b,c,d)),其头尾链表为: 1 C 0 a 1 ^ 1 0 b 1 0 c 1 ^ 0 d * 2、广义表的扩展线性链表存储表示: typedef enum {ATOM,LIST}ElemTag; //ATOM==0:原子,LIST==1:子表 typedef struct GLNode{ ElemTag tag; //公共部分,用来区分原子结点和表结点 Union{//原子结点和表结点的联合部分 AtomType atom;//原子结点的值域 Struct GLNode *

文档评论(0)

smashing + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档