数据结s构课件c语言描述第5章.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结s构课件c语言描述第5章

switch ( ls-utype ) { case 0: q-value.ref = ls-value.ref; break; case 1: q-value.intgrinfo = ls-value.intgrinfo; break; case 2: q-value.charinfo = ls-value.charinfo; break; case 3: q-value.hlink = Copy (ls-value.hlink); } q-tlink = Copy (ls-tlink); } return q; } ? ? ? 求广义表的深度 例如,对于广义表 E (B (a, b), D (B (a, b), C (u, (x, y, z)), A ( ) ) ) 1 1 1 1 2 3 4 int GenList :: depth ( GenListNode *ls ) { if ( ls-tlink == NULL ) return 1; //空表 GenListNode * temp = ls-tlink; int m = 0; while ( temp != NULL ) { //在表顶层横扫 if ( temp-utype == 3 ) { //结点为表结点 int n = depth ( temp-value.hlink ); if ( m n ) m = n; //m记最大深度 } temp = temp-tlink; } return m+1; } int GenList :: depth ( ) { return depth ( first ); } 广义表的删除算法 0 1 1 5 3 3 1 2 ? 0 1 2 ‘x’ ? 0 1 0 1 2 ‘y’ ls 3 2 ‘x’ ? ? 扫描子链表 若结点数据为‘x’, 删除。可能做循环连续删。 若结点数据不为‘x’,不执行删除。 若结点为子表,递归在子表执行删除。 扫描子链表 若结点数据为‘x’, 删除。可能做循环连续删。 若结点数据不为‘x’,不执行删除。 若结点为子表,递归在子表执行删除。 void delvalue(GenListNode * ls, const value x) { //在广义表中删除所有含 x 的结点 if ( ls-tlink != NULL ) { //非空表 GenListNode * p = ls-tlink; while ( p != NULL //横扫链表 ( ( p-utype == 1 p-value.intinfo == x ) || ( p-utype == 2 p-value.charinfo == x ) ) { ls-tlink = p-tlink; delete p; //删除 p = ls-tlink; //指向同一层后继结点 } if ( p != NULL ) { if ( p-utype == 3 ) //在子表中删除 delvalue ( p-value.hlink, x ); delvalue ( p, x ); //在后续链表中删除 } } } GenList :: ~GenList ( ) { //析构函数 Remove ( first ); delete (first); } void GenList :: Remove ( GenListNode *ls ) { //私有函数:释放以 ls 为表头指针的广义表 ls-value.ref --; //引用计数减1 if (

文档评论(0)

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

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

1亿VIP精品文档

相关文档