需求和规格说明.docVIP

  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文档。上传文档
查看更多
需求和规格说明

1.需求和规格说明 1先序建立一个二叉树 2用递归方式实现二叉树的先中后序遍历 3用非递归方式实现二叉树的中序遍历。 面向对象编程,可视化MFC 界面。 2.设计 2.1设计思想 遍历算法   1.中序遍历的定义:   若二叉树非空,则依次执行如下操作:   (1)遍历左子树;   (2)访问根结点;   (3)遍历右子树。   2.先序遍历的递归算法定义:   若二叉树非空,则依次执行如下操作:   (1) 访问根结点;   (2) 遍历左子树;   (3) 遍历右子树。   3.后序遍历得递归算法定义:   若二叉树非空,则依次执行如下操作:   (1)遍历左子树;   (2)遍历右子树;   (3)访问根结点。 统一设定坐标值 算法: (x,y)[I,j]=(x-(2H-1-2H-1-i)*D0+j* D0*2H-i,y+H0*i) nl=2np+1; nr=2np+2;d nroot =0; n=i+j 1 H0 结点层距 2 D0 二叉树中相邻叶子结点间的距离 3 [I,j]结点的标识,表示第i行的第j个结点 4 (x,y)[I,j] 第i行第y个结点坐标值 5 nroot 根结点编号 6H 二叉树的高度 7n结点的编号 8 np 父亲结点编号 9nl 左孩子编号 nr 右孩子编号 2.2 设计表示 class TreeNode { public: CString data; TreeNode * leftchild; TreeNode * rightchild; int code; TreeNode(); TreeNode(char d); virtual ~TreeNode(); }; class BinaryTree { public: int GetDepth(TreeNode *tree,int* num);//获取树的深度,及其结点数目 void CreateBinTree(TreeNode **T,CString cst);//建立二叉树 BinaryTree(); virtual ~BinaryTree(); }; void BinaryTree::CreateBinTree(TreeNode **T, CString cst)//先序建立一棵二叉树 { if (cst.GetAt(ic)==#) {*T=NULL;ic++;} else { (*T)=new TreeNode(cst.GetAt(ic)); ic++; CreateBinTree((*T)-leftchild,cst); CreateBinTree((*T)-rightchild,cst); } } int BinaryTree::GetDepth(TreeNode *tree,int * num) { ic=0; int dep1,dep2; if (tree==NULL)return 0; else { (*num)++; dep1=GetDepth(tree-leftchild,num); dep2=GetDepth(tree-rightchild,num); return dep1dep2?dep1+1:dep2+1; } } class CDrawTreeTOScreen { public: void post_order(TreeNode *ptree, CDC *DC, CString cst);//后序遍历 void in_order(TreeNode *ptree, CDC *DC,CString cst);//中序遍历 void pre_order(TreeNode *ptree,CDC *DC,CString cst);//先序遍历 void visit(TreeNode *ptree,CString cst,CDC *DC);//访问结点 void DrawTree(TreeNode *tree,CDC *DC);//先序画树 void DrawNode(TreeNode *tree,CDC* DC);//画一个结点 void DrawBinaryTree(CPoint pt,CDC *DC);//画一棵完整的二叉树 void CreateCPArray(CPoint orgin);//建立一个坐标数组 void SetCode(TreeNode *tree);//给树节点编号 CDrawTreeTOScreen(); virtual ~CDrawTreeTOScreen(); }; void CDrawTreeTOScreen::post_order(TreeNod

文档评论(0)

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

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

1亿VIP精品文档

相关文档