数据结构 广义表_第1页
数据结构 广义表_第2页
数据结构 广义表_第3页
数据结构 广义表_第4页
数据结构 广义表_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、8.1 8.1 广义表的定义广义表的定义第第8 8章章 广义表广义表8.2 8.2 广义表的存储结构广义表的存储结构8.3 8.3 广义表的运算广义表的运算本章小结本章小结8.1 8.1 广义表的定义广义表的定义 广义表简称表广义表简称表,它是线性表的推广。一个广义它是线性表的推广。一个广义表是表是n(n0)个元素的一个序列个元素的一个序列,若若n=0时则称为空时则称为空表。设表。设ai为广义表的第为广义表的第i个元素个元素,则广义表则广义表GL的一的一般表示与线性表相同:般表示与线性表相同: GL=(a1,a2,ai,an) 其中其中n表示广义表的长度表示广义表的长度,即广义表中所含元即广义

2、表中所含元素的个数素的个数,n0。如果。如果ai是单个数据元素是单个数据元素,则则ai是广是广义表义表GL的原子;如果的原子;如果ai是一个广义表是一个广义表,则则ai是广义是广义表表GL的子表。的子表。 广义表具有如下重要的特性:广义表具有如下重要的特性: (1)广义表中的数据元素有相对次序;广义表中的数据元素有相对次序; (2)广义表的长度定义为最外层包含元素个数;广义表的长度定义为最外层包含元素个数; (3)广义表的深度定义为所含括弧的重数。其中广义表的深度定义为所含括弧的重数。其中,原原子的深度为子的深度为0,空表的深度为空表的深度为1; (4)广义表可以共享;一个广义表可以为其他广义

3、广义表可以共享;一个广义表可以为其他广义表共享;这种共享广义表称为再入表;表共享;这种共享广义表称为再入表; (5)广义表可以是一个递归的表。一个广义表可以广义表可以是一个递归的表。一个广义表可以是自已的子表。这种广义表称为递归表。递归表的是自已的子表。这种广义表称为递归表。递归表的深度是无穷值深度是无穷值,长度是有限值;长度是有限值; (6)任何一个非空广义表任何一个非空广义表GL均可分解为表头均可分解为表头head(GL) = a1和表尾和表尾tail(GL) = ( a2,an) 两部分。两部分。 为了简单起见为了简单起见,下面讨论的广义表不包括前面定下面讨论的广义表不包括前面定义的再入

4、表和递归表义的再入表和递归表,即只讨论一般的广义表。另即只讨论一般的广义表。另外外,我们规定用小写字母表示原子我们规定用小写字母表示原子,用大写字母表示用大写字母表示广义表的表名。例如:广义表的表名。例如: A=() B=(e) C=(a,(b,c,d) D=(A,B,C)=(),(e),(a,(b,c,d) E=(a,(a,b),(a,b),c) 如果把每个表的名字如果把每个表的名字(若有的话若有的话)写在其表的前面写在其表的前面,则则上面的上面的5个广义表可相应地表示如下:个广义表可相应地表示如下: A() B(e) C(a,(b,c,d) D(A(),B(e),C(a,(b,c,d) E

5、(a,(a,b),(a,b),c) 若用圆圈和方框分别表示表和单元素若用圆圈和方框分别表示表和单元素,并用线段把表并用线段把表和它的元素和它的元素(元素结点应在其表结点的下方元素结点应在其表结点的下方)连接起来连接起来,则则可得到一个广义表的图形表示。例如可得到一个广义表的图形表示。例如,上面五个广义表上面五个广义表的图形表示如下图所示。的图形表示如下图所示。 c a b a b E d e a b c D A B C d b c C a B e A a A() B(e) C(a,(b,c,d) D(A(),B(e),C(a,(b,c,d)E(a,(a,b),(a,b),c)8.2 8.2 广

6、义表的存储结构广义表的存储结构 广义表是一种递归的数据结构广义表是一种递归的数据结构,因此很难为每个因此很难为每个广义表分配固定大小的存储空间广义表分配固定大小的存储空间,所以其存储结构只所以其存储结构只好采用动态链式结构。好采用动态链式结构。 我们将一个广义表看成一棵树我们将一个广义表看成一棵树,为了方便存储为了方便存储,将将其转换成一棵二叉树。其转换过程已在第其转换成一棵二叉树。其转换过程已在第6章中介绍章中介绍过过,这里以示例中的广义表这里以示例中的广义表C说明其转换过程。如下说明其转换过程。如下图所示图所示,左边的图表示转换的中间状态左边的图表示转换的中间状态,右边的图表示右边的图表示

7、转换的最终状态转换的最终状态,即一棵二叉树。从二叉树中看到即一棵二叉树。从二叉树中看到,有有两类结点两类结点,一类为圆圈结点一类为圆圈结点,在这里对应子表;另一类在这里对应子表;另一类为方形结点为方形结点,在这里对应原子。在这里对应原子。 C a b c d C a b c d C 1 0 a 1 0 b 0 c 0 d 广义表的存储结构广义表的存储结构 typedef struct lnode int tag; /*结点类型标识结点类型标识*/ union ElemType data; struct lnode *sublist; val; struct lnode *link;/*指向下一

8、个元素指向下一个元素*/ GLNode;/*广义表结点类型定义广义表结点类型定义*/广义表的两种基本情况广义表的两种基本情况 : g1 1 g2 1 * * * * * * 第 1 个元素 第 2 个元素 第 n 个元素 (a)空表 (b)非空表 为原子的情况为原子的情况 : g3 0 a 8.3 8.3 广义表的运算广义表的运算1. 求广义表的长度求广义表的长度 在广义表中在广义表中,同一层次的每个结点是通过同一层次的每个结点是通过link域链域链接起来的接起来的,所以可把它看做是由所以可把它看做是由link域链接起来的单域链接起来的单链表。这样链表。这样,求广义表的长度就是求单链表的长度求

9、广义表的长度就是求单链表的长度,可可以采用以前介绍过的求单链表长度的方法求其长度。以采用以前介绍过的求单链表长度的方法求其长度。求广义表长度的非递归算法如下:求广义表长度的非递归算法如下: int GLLength(GLNode *g) /*g为一个广义表头结点的指针为一个广义表头结点的指针*/ int n=0; g=g-val.sublist;/*g指向广义表的第一个元素指向广义表的第一个元素*/ while (g!=NULL) n+; g=g-link; return n; 2. 求广义表的深度求广义表的深度 对于带头结点的广义表对于带头结点的广义表g,广义表深度的递归定义广义表深度的递归

10、定义是它等于所有子表中表的最大深度加是它等于所有子表中表的最大深度加1。若。若g为原子为原子,其深度为其深度为0。 求广义表深度的递归模型求广义表深度的递归模型f()如下:如下:f(g)= 0 若若g为原子为原子 1 若若g为空表为空表MAXf(subg)+1 其他情况其他情况,subg为为g的子表的子表 int GLDepth(GLNode *g) /*求带头结点的广义表求带头结点的广义表g的深度的深度*/ int max=0,dep; if (g-tag=0) return 0; /*为原子时返回为原子时返回0*/ g=g-val.sublist; /*g指向第一个元素指向第一个元素*/

11、if (g=NULL) return 1; /*为空表时返回为空表时返回1*/ while (g!=NULL) /*遍历表中的每一个元素遍历表中的每一个元素*/ if (g-tag=1) /*元素为子表的情况元素为子表的情况*/ dep=GLDepth(g); /*递归调用求出子表的深度递归调用求出子表的深度*/ if (depmax) max=dep; /*max为同一层所求过的子表中深度的最大值为同一层所求过的子表中深度的最大值*/ g=g-link; /*使使g指向下一个元素指向下一个元素*/ return(max+1); /*返回表的深度返回表的深度*/3. 建立广义表的链式存储结构建

12、立广义表的链式存储结构 假定广义表中的元素类型假定广义表中的元素类型ElemType为为char类型类型,每每个原子的值被限定为英文字母。个原子的值被限定为英文字母。 并假定广义表是一个表达式并假定广义表是一个表达式,其格式为:元素之间用其格式为:元素之间用一个逗号分隔一个逗号分隔,表元素的起止符号分别为左、右圆括号表元素的起止符号分别为左、右圆括号,空表在其圆括号内不包含任何字符。例如空表在其圆括号内不包含任何字符。例如“(a,(b,c,d)”就是一个符合上述规定的广义表格式。就是一个符合上述规定的广义表格式。 生成广义表链式存储结构的算法如下:生成广义表链式存储结构的算法如下:GLNode

13、 *CreatGL(char *&s) GLNode *h;char ch=*s+; /*取一个扫描字符取一个扫描字符*/ if (ch!=0) /*串未结束判断串未结束判断*/ h=(GLNode *)malloc(sizeof(GLNode);/*创建新结点创建新结点*/ if (ch=() /*当前字符为左括号时当前字符为左括号时*/ h-tag=1; /*新结点作为表头结点新结点作为表头结点*/ h-val.sublist=CreatGL(s); /*递归构造子表并链到表头结点递归构造子表并链到表头结点*/ else if (ch=) h=NULL; /*遇到遇到)字符字符,子

14、表为空子表为空*/ else h-tag=0; /*新结点作为原子结点新结点作为原子结点*/ h-val.data=ch; else h=NULL; /*串结束串结束,子表为空子表为空*/ ch=*s+; /*取下一个扫描字符取下一个扫描字符*/ if (h!=NULL) /*串未结束判断串未结束判断*/ if (ch=,) /*当前字符为当前字符为,*/ h-link=CreatGL(s); /*递归构造后续子表递归构造后续子表*/ else /*串结束串结束*/ h-link=NULL; /*处理表的最后一个元素处理表的最后一个元素*/ return h; /*返回广义表指针返回广义表指针

15、*/ 4. 输出广义表输出广义表 以以h作为带表头附加结点的广义表的表头指针作为带表头附加结点的广义表的表头指针,打印输打印输出该广义表时出该广义表时,需要对子表进行递归调用。输出一个广义需要对子表进行递归调用。输出一个广义表的算法如下:表的算法如下:void DispGL(GLNode *g) /*g为一个广义表的头结点指针为一个广义表的头结点指针*/ if (g!=NULL) /*表不为空判断表不为空判断*/ if (g-tag=1) /*为表结点时为表结点时*/ printf(); /*输出输出(*/ if (g-val.sublist=NULL) printf(); /*输出空子表输出空子表*/ else DispGL(g-val.sublist); /*递归输出子表递归输出子表*/ else printf(%c, g-val.data); /*为原子时输出元素值为原子时输出元素值*/ if (g-tag=1) printf(); /*为表结点时输出为表结点时输出)*/ if (g-link!=NULL) printf(,); DispGL(g-link); /*递归输出后续表的内容递归输出后续

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论