- 1、本文档共15页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C二叉树结构的建立与基本操作课案
C++二叉树结构的建立与基本操作
二叉树是数据结构中的树的一种特殊情况,有关二叉树的相关概念,这里不再赘述,如果不了解二叉树相关概念,建议先学习数据结构中的二叉树的知识点
准备数据
定义二叉树结构操作中需要用到的变量及数据等。
复制代码 代码如下:
#define MAXLEN 20 //最大长度
typedef char DATA; //定义元素类型
struct CBTType //定义二叉树结点类型
{
DATA data; //元素数据
CBTType * left; //左子树结点指针
CBTType * right; //右子树结点指针
};
定义二叉树结构数据元素的类型DATA以及二叉树结构的数据结构CBTType。结点的具体数据保存在一个姐都DATA中,而指针left用来指向左子树结点,指针right用来指向右子树结点
初始化二叉树
初始化二叉树,将一个结点设置为二叉树的根结点。
复制代码 代码如下:
CBTType * InitTree()
{
CBTType * node;
if(node = new CBTType) //申请内存
{
cout请先输入一个根节点数据:endl;
cinnode-data;
node-left=NULL;
node-right=NULL;
if(node!=NULL) //如果二叉树结点不为空
{
return node;
} else
{
return NULL;
}
}
return NULL;
}
首先申请一个结点,然后用户输入根结点 的数据,并将左子树和右子树的指针置为空,即可完成二叉树的初始化工作。
查找结点
查找结点就是遍历二叉树中的每一个节点,逐个比较数据,当找到目标数据时将返回该数据所在结点的指针。
复制代码 代码如下:
CBTType *TreeFindNode(CBTType *treeNode,DATA data)
{
CBTType *ptr;
if(treeNode==NULL)
{
return NULL;
}else
{
if(treeNode-data==data)
{
return treeNode;
}
else //分别向左右子树查找
{
if(ptr=TreeFindNode(treeNode-left,data)) //左子树递归查找
{
return ptr;
}
else if(ptr=TreeFindNode(treeNode-right,data)) //右子树递归查找
{
return ptr;
}
else
{
return NULL;
}
}
}
}
输入参数treeNode为待查找的二叉树的根结点,输入参数data为待查找的结点数据。程序中首先判断根结点是否为空,然后根据数据判断是否为根结点,然后分别向左右子树进行查找,采用递归的方法进行查找,查找到该结点则返回结点对应的指针;如果全都查找不到,则返回NULL。
添加结点
添加结点就是在二叉树中添加结点数据,添加结点时除了要输入结点数据外,还需要指定其父结点,以及添加的结点作为左子树还是右子树。然后将该结点置为其父结点的左子树或者右子树。
复制代码 代码如下:
void AddTreeNode(CBTType *treeNode)
{
CBTType *pnode,*parent;
DATA data;
char menusel;
if(pnode=new CBTType) //分配内存
{
cout输入二叉树结点数据:endl;
cinpnode-data;
pnode-left=NULL; //设置左子树为空
pnode-right=NULL; //设置左子树为空
cout输入该结点的父结点数据endl;
cindata;
parent=TreeFindNode(treeNode,data);//查找父结点,获得结点指针
if(!parent)
{
cout没有找到父结点endl;
delete pnode;
return ;
}
cout1.添加该结点到左子树;2.添加该结点到右子树。请输入操作对应的数字。endl;
do
{
cinmenusel;
if(menusel==1||menusel==
您可能关注的文档
- BSS中级试题hanwei课案.doc
- 全球变暖与防治对策.pptx
- 党的光荣传统教育.ppt
- 全国卷历史复习应注意的几点.ppt
- 全球化与管理.ppt
- BSC指令集解析.doc
- BW建模转换和DTP.doc
- BSS呼叫流程与实际接口分析.ppt
- Bug书写规范V1.pptx
- 全球性的灾难.pptx
- 广东粤电天然气有限公司招聘笔试题库2025.pdf
- 《租赁风险与保险》课件.ppt
- 盘)安装工艺标准.pdf
- 广东省旅游控股集团招聘笔试题库2025.pdf
- [丽江]2024年下半年云南丽江市中医医院第二次招聘编外人员4人笔试历年参考题库附带答案详解.docx
- [丽水]2025年浙江丽水龙泉市城市开发建设中心招聘工作人员笔试历年参考题库附带答案详解.docx
- [丽水]2025年浙江丽水龙泉市教育系统紧缺急需人才引进14人笔试历年参考题库附带答案详解.docx
- 《秘书职能范畴》课件.ppt
- [丽江]2024年下半年云南丽江市中医医院急需紧缺卫生技术人员招聘笔试历年参考题库附带答案详解.docx
- 《秘书长办》课件.ppt
文档评论(0)