精品数据结构GeneralTrees_第1页
精品数据结构GeneralTrees_第2页
精品数据结构GeneralTrees_第3页
精品数据结构GeneralTrees_第4页
精品数据结构GeneralTrees_第5页
已阅读5页,还剩12页未读 继续免费阅读

下载本文档

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

文档简介

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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论