版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、general treesgeneral tree node/ general tree node adttemplate class gtnode public: gtnode(const elem&); / constructor gtnode(); / destructor elem value(); / return value bool isleaf(); / true if is a leaf gtnode* parent(); / return parent gtnode* leftmost_child(); / first child gtnode* right_sib
2、ling(); / right sibling void setvalue(elem&); / set value void insert_first(gtnode* n); void insert_next(gtnode* n); void remove_first(); / remove first child void remove_next(); / remove sibling;general tree traversaltemplate void gentree:printhelp(gtnode* subroot) if (subroot-isleaf() cout lea
3、f: ; else cout internal: ; cout value() n; for (gtnode* temp = subroot-leftmost_child(); temp != null; temp = temp-right_sibling() printhelp(temp); parent pointer implementationequivalence class problemthe parent pointer representation is good for answering:are two elements in the same tree?/ return
4、 true if nodes in different treesbool gentree:differ(int a, int b) int root1 = find(a); / find root for a int root2 = find(b); / find root for b return root1 != root2; / compare rootsunion/findvoid gentree:union(int a, int b) int root1 = find(a); / find root for a int root2 = find(b); / find root fo
5、r b if (root1 != root2) arrayroot2 = root1;int gentree:find(int curr) const while (arraycurr!=root) curr = arraycurr; return curr; / at rootwant to keep the depth small.weighted union rule: join the tree with fewer nodes to the tree with more nodes.equiv class processing (1)equiv class processing (2
6、)path compressionint gentree:find(int curr) const if (arraycurr = root) return curr; return arraycurr = find(arraycurr);lists of childrenleftmost child/right sibling (1)leftmost child/right sibling (2)linked implementations (1)linked implementations (2)converting to a binary treeleft child/right sib
7、ling representation essentially stores a binary tree.use this process to convert any general tree to a binary tree.a forest is a collection of one or more general trees.sequential implementations (1)list node values in the order they would be visited by a preorder traversal.saves space, but allows only sequential access.need to retain tree structure for reconstruction.example: for binary trees, us a symbol to mark null links.ab/d/ceg/fh/i/sequential implementations (2)example: for full bina
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 档案职业资格认证制度
- 七星分公司管理规范制度
- 咖啡馆警卫室管理制度规范
- 档案工作制度上墙图
- 心理学档案移交制度
- 保教人员业务档案制度
- 档案管理日常考核制度
- 情感交流室制度规范要求
- 大学班级规范及考核制度
- 幼儿园资助档案工作制度
- 2026年广东高考数学卷及答案
- 2026年高端化妆品市场分析报告
- 2025年中国铁路南宁局招聘笔试及答案
- 2024年内蒙古交通职业技术学院单招职业技能考试题库附答案解析
- 2025年学校领导干部民主生活会“五个带头”对照检查发言材料
- 机台故障应急预案(3篇)
- 2025年轻型民用无人驾驶航空器安全操控(多旋翼)理论备考试题及答案
- 景区服务培训课件
- 2025年深圳低空经济中心基础设施建设研究报告
- 中科曙光入职在线测评题库
- 档案法解读课件
评论
0/150
提交评论