- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
设计思想
递归实现二叉树遍历的思想:
1.要遍历二叉树首先的问题是创立二叉树。二叉树的创立可以采用很多的方法。例如:先序,中序,后序,还可以采用层次的方法创立二叉树。本程序采用的是先序递归的方式创立的二叉树。
2.然后是中序,先序,后序递归遍历二叉树。递归的思想是一直调用方法本身。
3.中序递归遍历二叉树的思想是先访问左子树,然后访问根节点,最后访问右子树。当访问左子树或是右子树的时候,实际上调用的是函数本身。在这里就表达了递归的思想,当函数的返回值是0的时候,那么返回上一次的程序,继续执行下面的语句。
4.先序递归遍历二叉树的思想是先访问根节点,然后访问左子树,最后访问右子树。同样如步骤3的方式相同,当访问左子树或者是右子树的收,实际上调用的是函数本身,直到返回值是0的时候,返回上一层的程序继续执行。
5.后序递归遍历二叉树的思想是先访问左子树,然后访问右子树,最后访问根节点。
同样跟步骤3的方式相同,当访问左子树或者右子树的时候实际上是调用的是方法本
直到有返回值的时候才返回上一层的程序,继续执行.
非递归实现二叉树遍历的思想:
跟递归遍历二叉树的前提一样,首先应该创立一个二叉树,同样使用先序递归的方式创立二叉树。
然后是中序,先序,后序非递归遍历二叉树。
中序非递归遍历二叉树的思想是:首先是根节点压栈,当根节点的左子树不是空的时候,左子树压栈。直到左子树为空的时候,不再压栈。将栈顶元素出栈,访问栈顶元素,并将栈顶的右子树进栈。当右子树的左子树不是空的时候,左子树一直进栈,直到左子树为空,那么不再进栈。重复上面的操作,直到栈空的时候。
4.先序非递归遍历二叉树的思想是:首先是根节点进栈,然后当栈不为空的时候,将栈顶元素出栈,然后访问。同时将出栈元素的右子树进栈,左子树进栈。重复上面的操作,直到栈为空。
5.后序非递归遍历二叉树的思想:首先是根节点进栈,当根节点的左子树不为空的时候,左子树进栈,直到左为空的时候,左子树不再进栈。指针指向的是右子树,当右子树为空的时候,直接访问根节点。当右子树不为空的时候,那么右子树的指针进栈,当右子树的左子树不为空的时候,那么左也进栈,直到左为空。重复上面的操作,直到栈为空的时候,那么遍历树完成。
二、算法流程图
递归方法遍历二叉树的流程图如图1
开始
开始
创立二叉树
输入要遍历的二叉树
B!=NUll
访问根节点
先序遍历(左子树)
先序遍历(右子树)
先序遍历
中序遍历
B!=NULL
中序遍历(左子树)
访问根节点
中序遍历(右子树)
后序遍历
B!=NULL
后序遍历(左子树)
后序遍历(右子树)
访问根节点
结束
结束
结束
Y
N
N
Y
Y
N
图1递归方法遍历二叉树流程图
非递归先序遍历二叉树流程图
图2:非递归先序遍历二叉树流程图
后序非递归遍历二叉树流程图如图3
图3后序非递归遍历二叉树流程图
中序非递归遍历二叉树流程图4
图4:中序非递归遍历二叉树流程
三、源代码
用递归的方式实现二叉树的遍历
#includestdio.h
#includeconio.h
#includestdlib.h
/*定义二叉树*/
typedefstructnode{
chardata;
structnode*lchild,*rchild;
}BinTnode;
typedefBinTnode*BinTree;//定义二叉树类型的指针
/*先序创立二叉树*/
intCreateBinTree(BinTree*T){/*BinTree本身是一种类型,是一个指针,是指向结果体指针的类型*///这算是问题一
//问题二是:关于栈的各种各样的操作,进栈,进的应该是指向树根的指针
//问题三是:为什么要定义一个指向指针的指针????????????
charch;
*T=(BinTree)malloc(sizeof(BinTnode));
if(!*T)printf(overflow);
do{
ch=getchar();
if(ch==)
{*T=NULL;
return0;
}
else{
(*T)-data=ch;
CreateBinTree(((*T)-lchild));
CreateBinTree(((*T)-rchild));
return1;
}
}while(ch!=\0
您可能关注的文档
- 硫的知识点和练习(经典总结)Microsoft-Word-文档.doc
- 盖板涵施工方案(简洁全面).doc
- 二年级知识竞赛.ppt
- 人教版五年级下册-《口语交际·习作一》课件.ppt
- 五年级语文下册第一单元复习课件.ppt
- 人教版四年级下册语文第四单元-13课.ppt
- 主题班会课件:让生命之花绽放光彩——“生命教育.ppt
- 五年级语文(下册)百花园三.ppt
- 五年级下册期中作文复习.ppt
- 云南工商学院系列安全教育之十三预防诈骗.ppt
- 英语人教PEP版八年级(上册)Unit4+writing+写作.pptx
- 人美版美术四年级(上册)8 笔的世界 课件 (1).pptx
- 人美版美术七年级(上册)龙的制作.pptx
- 英语人教PEP版六年级(上册)Unit 2 第一课时.pptx
- 数学苏教版三年级(上册)3.3 长方形和正方形周长的计算 苏教版(共12张PPT).pptx
- 音乐人教版八年级(上册)青春舞曲 课件2.pptx
- 音乐人教版四年级(上册) 第一单元 音乐知识 附点四分音符|人教版.pptx
- 英语人教PEP版四年级(上册)Unit 6 Part B let's learn 1.pptx
- 道德与法治人教版二年级(上册)课件-3.11大家排好队部编版(共18张PPT).pptx
- 人美版美术七年级(上册)《黄山天下奇》课件1.pptx
最近下载
- 七年级音乐《彩色的中国》课件.ppt VIP
- 耳鼻喉科术后感染预防PDCA循环案例.pptx VIP
- 干部管理-华为学习材料.pdf VIP
- 华为干部管理七步曲.pdf VIP
- 外研版小学五年级英语上册《Module 5 Unit 1 There are only nineteen crayons 》教学教案.doc VIP
- 2018年春二年级下册道法教案.pdf VIP
- 高中体育新课标程准考试试题.doc VIP
- 甲亢甲减的相关知识与护理PPT课件.pptx VIP
- 新人教pep三年级上册Unit2 Different families PartA talk &learn 课件.ppt
- 九年级化学培优辅差工作总结 .pdf VIP
文档评论(0)