、c语言 二叉树 任务:建立二叉树,并实现二叉树的遍历以及求根结点到指定结点的路径。 功能要求: 1) 建立二叉树存储结构; 2) 对二叉树进行先序、中序、后序、层序遍历,并输出对应遍历序列; 3) 求根结点到指定结点的路径。 界面要求:程序运行后,给出菜单项的内容和输入提示: 1. 建立二叉树存储结构 2. 求二叉树的先序遍历序列 3. 求二叉树的中序遍历序列 4. 求二叉树的后序遍历序列 5. 求二叉树的层序遍历序列 6. 求根结点到指定结点的路径 0. 退出 请选择0-5:

时间: 2024-03-18 08:42:19 浏览: 14
好的,以下是一个基本的C语言二叉树程序,包括建立二叉树存储结构、二叉树的先序遍历、中序遍历、后序遍历、层序遍历以及求根节点到指定节点的路径。请注意,此程序是基于静态数组实现的,因此在实际应用中可能会受到内存大小的限制。 ```c #include <stdio.h> #include <stdlib.h> #define MAXSIZE 100 // 定义静态数组大小 #define ElemType char // 定义树节点类型为字符型 typedef struct Node{ // 树节点结构体 ElemType data; // 数据域 struct Node *lchild, *rchild; // 左右子树指针 } Node, *pNode; int createTree(pNode *root); // 建立二叉树 void preOrder(pNode root); // 先序遍历 void inOrder(pNode root); // 中序遍历 void postOrder(pNode root); // 后序遍历 void levelOrder(pNode root); // 层序遍历 int getPath(pNode root, ElemType target, pNode path[], int *len); // 求根节点到指定节点的路径 int main(){ pNode root = NULL; int choice, len; pNode path[MAXSIZE]; while(1){ printf("---------------------\n"); printf("1. 建立二叉树存储结构\n"); printf("2. 求二叉树的先序遍历序列\n"); printf("3. 求二叉树的中序遍历序列\n"); printf("4. 求二叉树的后序遍历序列\n"); printf("5. 求二叉树的层序遍历序列\n"); printf("6. 求根结点到指定结点的路径\n"); printf("0. 退出\n"); printf("---------------------\n"); printf("请选择0-6:"); scanf("%d", &choice); switch(choice){ case 1: createTree(&root); break; case 2: printf("先序遍历序列:"); preOrder(root); printf("\n"); break; case 3: printf("中序遍历序列:"); inOrder(root); printf("\n"); break; case 4: printf("后序遍历序列:"); postOrder(root); printf("\n"); break; case 5: printf("层序遍历序列:"); levelOrder(root); printf("\n"); break; case 6: printf("请输入要查找的节点:"); ElemType target; scanf(" %c", &target); len = 0; if(getPath(root, target, path, &len)){ printf("根节点到节点%c的路径为:", target); for(int i = 0; i < len-1; i++){ printf("%c->", path[i]->data); } printf("%c\n", path[len-1]->data); } else{ printf("未找到节点%c\n", target); } break; case 0: exit(0); default: printf("输入错误,请重新选择!\n"); } } return 0; } int createTree(pNode *root){ ElemType data; printf("请输入节点数据(#代表空节点):"); scanf(" %c", &data); if(data == '#'){ // 空节点 *root = NULL; } else{ *root = (pNode)malloc(sizeof(Node)); // 动态分配节点空间 if(!(*root)){ // 内存分配失败 printf("内存分配失败!\n"); exit(-1); } (*root)->data = data; // 存储节点数据 createTree(&((*root)->lchild)); // 递归建立左子树 createTree(&((*root)->rchild)); // 递归建立右子树 } return 1; } void preOrder(pNode root){ if(root){ // 节点不为空 printf("%c ", root->data); // 输出节点数据 preOrder(root->lchild); // 递归遍历左子树 preOrder(root->rchild); // 递归遍历右子树 } } void inOrder(pNode root){ if(root){ // 节点不为空 inOrder(root->lchild); // 递归遍历左子树 printf("%c ", root->data); // 输出节点数据 inOrder(root->rchild); // 递归遍历右子树 } } void postOrder(pNode root){ if(root){ // 节点不为空 postOrder(root->lchild); // 递归遍历左子树 postOrder(root->rchild); // 递归遍历右子树 printf("%c ", root->data); // 输出节点数据 } } void levelOrder(pNode root){ if(!root) return; // 树为空 pNode queue[MAXSIZE]; // 定义节点队列 int front = -1, rear = -1; // 队头、队尾指针 queue[++rear] = root; // 根节点入队 while(front != rear){ // 队列不为空 pNode p = queue[++front]; // 取出队头元素 printf("%c ", p->data); // 输出节点数据 if(p->lchild) queue[++rear] = p->lchild; // 左子树不为空,左子树入队 if(p->rchild) queue[++rear] = p->rchild; // 右子树不为空,右子树入队 } } int getPath(pNode root, ElemType target, pNode path[], int *len){ if(!root) return 0; // 树为空 path[*len] = root; // 当前节点入栈 (*len)++; // 栈指针+1 if(root->data == target){ // 如果找到目标节点 return 1; } if(getPath(root->lchild, target, path, len) || getPath(root->rchild, target, path, len)){ // 在左右子树中查找目标节点 return 1; } (*len)--; // 回溯,栈指针-1 return 0; // 未找到目标节点 } ``` 这是一个基本的二叉树程序,您可以根据需要进行修改和完善。需要注意的是,此程序没有进行内存释放,在实际应用中需要注意避免内存泄露问题。

相关推荐

最新推荐

recommend-type

数据结构综合课设二叉树的建立与遍历.docx

建立一棵二叉树,并对其进行遍历(先序、中序、后序),打印输出遍历结果。 2.基本要求: 从键盘接受输入(先序),以二叉链表作为存储结构,建立二叉树(以先序来建立),并采用递归算法对其进行遍历(先序、中序...
recommend-type

C语言中计算二叉树的宽度的两种方式

主要介绍了C语言中计算二叉树的宽度的两种方式的相关资料,需要的朋友可以参考下
recommend-type

用Python实现二叉树、二叉树非递归遍历及绘制的例子

今天小编就为大家分享一篇用Python实现二叉树、二叉树非递归遍历及绘制的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

通过先序遍历和中序遍历后的序列还原二叉树(实现方法)

下面小编就为大家带来一篇通过先序遍历和中序遍历后的序列还原二叉树(实现方法)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
recommend-type

数据结构c语言版建立二叉树,中序非递归遍历(实验报告)

编写程序,用先序递归的方法建立二叉树,建立二叉树后,用中序非递归方法遍历该二叉树,并输出遍历序列。
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章

![:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章](https://img-blog.csdnimg.cn/img_convert/69b98e1a619b1bb3c59cf98f4e397cd2.png) # 1. 目标检测算法概述 目标检测算法是一种计算机视觉技术,用于识别和定位图像或视频中的对象。它在各种应用中至关重要,例如自动驾驶、视频监控和医疗诊断。 目标检测算法通常分为两类:两阶段算法和单阶段算法。两阶段算法,如 R-CNN 和 Fast R-CNN,首先生成候选区域,然后对每个区域进行分类和边界框回归。单阶段算法,如 YOLO 和 SSD,一次性执行检
recommend-type

ActionContext.getContext().get()代码含义

ActionContext.getContext().get() 是从当前请求的上下文对象中获取指定的属性值的代码。在ActionContext.getContext()方法的返回值上,调用get()方法可以获取当前请求中指定属性的值。 具体来说,ActionContext是Struts2框架中的一个类,它封装了当前请求的上下文信息。在这个上下文对象中,可以存储一些请求相关的属性值,比如请求参数、会话信息、请求头、应用程序上下文等等。调用ActionContext.getContext()方法可以获取当前请求的上下文对象,而调用get()方法可以获取指定属性的值。 例如,可以使用 Acti
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。