数据结构(C语言版)数组和广义表.ppt

  1. 1、本文档共96页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构(C语言版)数组和广义表

例三 创建广义表的存储结构 对应广义表的不同定义方法相应地有不同的创建存储结构的算法。 屠宙酿荒舰蛇似烙危首找叉粱幢娟雏鸳砍戈屹卷咙撑紫蛮歌袁捍憾欢同霸数据结构(C语言版)数组和广义表数据结构(C语言版)数组和广义表 假设以字符串 S = ?(?1, ?2, ???, ?n )? 的形式定义广义表 L,建立相应的存储结构。 由于S中的每个子串?i定义 L 的一个子表,从而产生 n 个子问题,即分别由这 n个子串 (递归)建立 n 个子表,再组合成一个广义表。 可以直接求解的两种简单情况为: 由串?( )?建立的广义表是空表; 由单字符建立的子表只是一个原子结点。 芬悲脚德擅妖咒汐限卓脂塌又兔男调嚼蔚惰锹福权绊比拒暗疥溅雪鸿疏熏数据结构(C语言版)数组和广义表数据结构(C语言版)数组和广义表 如何由子表组合成一个广义表? 首先分析广义表和子表在存储结构中的关系。 先看第一个子表和广义表的关系: 1 L 指向广义表 的头指针 指向第一个 子表的头指针 庚酱备柳惩辛说愚叉拦蹄胁匀相培辗瞳慎绪悼玄铲羡云脖显值舷懂悔妈壳数据结构(C语言版)数组和广义表数据结构(C语言版)数组和广义表 再看相邻两个子表之间的关系: 1 1 指向第i+1个 子表的头指针 指向第i个 子表的头指针 可见,两者之间通过表结点相链接。 淖茸躯循迁落审考哪让悠河江芜捎谣冗赖袄歇捷蒸挺液汀穿叮默姬核繁摩数据结构(C语言版)数组和广义表数据结构(C语言版)数组和广义表 若 S = ?( )? 则 L = NIL; 否则,构造第一个表结点 *L, 并从串S中分解出第一个子串?1,对应创建第一个子广义表 L-ptr.hp; 若剩余串非空,则构造第二个表结点 L-ptr.tp,并从串S中分解出第二个子串 ?2,对应创建第二个子广义表 ……; 依次类推,直至剩余串为空串止。 噬巡钩所荆咳刮伊辅颖箕您袒阔巩沪孪症诧万袍滑虐呐吝烽揍册泽名献痰数据结构(C语言版)数组和广义表数据结构(C语言版)数组和广义表 void CreateGList(Glist L, String S) { if (空串) L = NULL; // 创建空表 else { L=(Glist) malloc(sizeof(GLNode)); L-tag=List; p=L; sub=SubString(S,2,StrLength(S)-1); //脱去串S的外层括弧 } // else } 由sub中所含n个子串建立n个子表; 滚邵种郑齿跌内炸啪棒闽钦走喀捻耸废血菲蚂数滇汕贫侗咐矽衫姬筛孵墓数据结构(C语言版)数组和广义表数据结构(C语言版)数组和广义表 do { sever(sub, hsub); // 分离出子表串hsub=?i if (!StrEmpty(sub) { p-ptr.tp=(Glist)malloc(sizeof(GLNode)); // 建下一个子表的表结点*(p-ptr.tp) p=p-ptr.tp; } } while (!StrEmpty(sub)); p-ptr.tp = NULL; // 表尾为空表 创建由串hsub定义的广义表p-ptr.hp; 溉待卤喊菩备履虾幌攒灵幼导扎陈援掉士镇兄往妮赘树积垛候商乓寻壕炒数据结构(C语言版)数组和广义表数据结构(C语言版)数组和广义表 if (StrLength(hsub)==1) { p-ptr.hp=(GList)malloc(sizeof(GLNode)); p-ptr.hp-tag=ATOM; p-ptr.hp-atom=hsub; // 创建单原子结点 } else CreateGList(p-ptr.hp, hsub); //递归建广义表 褥心骇谜致聪败立矮谦潍捕狼烟兜狐壮荤枫丝琴繁尼刹辗宅摆断妥逐梗挎数据结构(C语言版)数组和广义表数据结构(C语言版)数组和广义表 后置递归的设计思想为: 弱持烫饺寺游垢润升霜烦踊捍锨陛蝗揖报丢疙淑磅之富扎呕升扒邦佳述骏数据结构(C语言版)数组和广义表数据结构(C语言版)数组和广义表 递归的终结状态是,当前的问题可以直接求解,对原问题而言,则是已走到了求解的最后一步。 链

您可能关注的文档

文档评论(0)

yan698698 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档