严蔚敏数据结构课件第五章
5. 可以用递归方程来表述递归函数的 时间性能。 例如: 假设解n个圆盘的梵塔的执行 时间为T(n) 则递归方程为: T(n) = 2T(n-1) + C, 初始条件为: T(0) = 0 1. 了解数组的两种存储表示方法,并掌握数组在以行为主的存储结构中的地址计算方法。 2. 掌握对特殊矩阵进行压缩存储时的下标变换公式。 3. 了解稀疏矩阵的两类压缩存储方法的特点和适用范围,领会以三元组表示稀疏矩阵时进行矩阵运算采用的处理方法。 4. 掌握广义表的结构特点及其存储表示方法,读者可根据自己的习惯熟练掌握任意一种结构的链表,学会对非空广义表进行分解的两种分析方法:即可将一个非空广义表分解为表头和表尾两部分或者分解为n个子表。 5. 学习利用分治法的算法设计思想编制递归算法的方法。 * * * * Status CopyGList(Glist T, Glist L) { if (!L) T = NULL; // 复制空表 else { if ( !(T = new GLNode) ) exit(OVERFLOW); // 建表结点 T-tag = L-tag; if (L-tag == ATOM) T-atom = L-atom; // 复制单原子结点 else { } } // else return OK; } // CopyGList 分别复制表头和表尾 CopyGList(T-ptr.hp, L-ptr.hp); // 复制求得表头T-ptr.hp的一个副本L-ptr.hp CopyGList(T-ptr.tp, L-ptr.tp); // 复制求得表尾T-ptr.tp 的一个副本L-ptr.tp 语句 CopyGList(T-ptr.hp, L-ptr.hp); 等价于 CopyGList(newhp, L-ptr.tp); T-ptr.hp = newhp; 例三 创建广义表的存储结构 对应广义表的不同定义方法相应地有不同的创建存储结构的算法。 假设以字符串 S = ?(?1, ?2, ???, ?n )? 的形式定义广义表 L,建立相应的存储结构。 由于S中的每个子串?i定义 L 的一个子表,从而产生 n 个子问题,即分别由这 n个子串 (递归)建立 n 个子表,再组合成一个广义表。 可以直接求解的两种简单情况为: 由串?( )?建立的广义表是空表; 由单字符建立的子表只是一个原子结点。 如何由子表组合成一个广义表? 首先分析广义表和子表在存储结构中的关系。 先看第一个子表和广义表的关系: 1 L 指向广义表 的头指针 指向第一个 子表的头指针 再看相邻两个子表之间的关系: 1 1 指向第i+1个 子表的头指针 指向第i个 子表的头指针 可见,两者之间通过表结点相链接。 若 S = ?( )? 则 L = NIL 否则 构造第一个表结点 *L, 并从串 S 中分解出第一个子串 ?1, 对应 创建第一个子广义表 L-ptr.hp; 若剩余串非空,则构造第二个表结点 L-ptr.tp, 并从串 S 中分解出第二个子串 ?2, 对应建第二个子广义表 ………; 依次类推,直至剩余串为空串止。 void CreateGList(Glist L, String S) { if (空串) L = NULL; // 创建空表 else { L = new GLNode; // 生成表结点 L-tag=List; p=L; sub=SubString(S,2,StrLength(S)-1); // 脱去串 S 的外层括弧 } // else } 由sub中所含n个子串建立n个子表; do { sever(sub, hsub); // 分离出子表串hsub=?i if (!StrEmpty(sub) { p-ptr.tp=new(sizeof(GLNode)); // 建下一个子表的表结点*(p-ptr.tp)
您可能关注的文档
- 两性关系 密码.ppt
- 两性文化与生育的关系.ppt
- 两法一条例ppt.ppt
- 两轴式手动变速器拆装检修教案.doc
- 严也是一种爱.ppt赵培.ppt
- 严也是一种爱新.ppt
- 严格才是大爱.ppt
- 严蔚敏数据结构课件第四章.ppt
- 严重创伤CT扫描.ppt
- 个人实际年度工作总结模板.docx
- 住院医师规范化培训《康复医学》习题(含参考答案)解析.docx
- 2025年5月住院医师规范化培训《耳鼻咽喉科》复习题(含参考答案).docx
- 2025年9月住院医师规范化培训《骨科》试题库(含答案).docx
- 2025年住院医师规范化培训《口腔修复科》模拟考试题+答案.docx
- 8月住院医师规范化培训《外科》测试题(附答案解析).docx
- 2025年6月住院医师规范化培训《预防医学科》练习题(附参考答案).docx
- 2025年7月住院医师规范化培训《放射科》习题(含参考答案).docx
- 2024年住院医师规范化培训《医学影像科》模拟试题(含答案).docx
- 住院医师规范化培训《神经外科》模考试题与参考答案.docx
- 3月住院医师规范化培训《康复医学》测试题+参考答案解析.docx
原创力文档

文档评论(0)