- 1、本文档共46页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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 *
您可能关注的文档
最近下载
- XGZ系列刮板输送机图册.pdf
- 第10课《 再塑生命的人》课件(共22张ppt)部编版语文七年级上册.pptx VIP
- 近5年上海市高考语文真题之书序、游记类文言文阅读汇编.docx VIP
- 00708装饰材料与构造-全国自考-2021年4月高等教育自学考试真题(试卷).pdf VIP
- XGZ系列铸石刮板输送机.doc
- 小学篮球原地运球、行进间运球教案.doc
- 中国林业研究院806有机化学考研真题试题2020年.pdf VIP
- 中国林业研究院806有机化学2019考研真题试题.pdf VIP
- 2024年初级咖啡师技能鉴定考试题库大全-上(单选题汇总).docx
- 2024-2030年中国氦(液氦和气态氦)行业市场发展趋势与前景展望战略分析报告.docx
文档评论(0)