///////////////////////
//bt.h
///////////////////////
#include <stdio.h>
#include "stack.h"
#ifndef _BT_H_
#define _BT_H_
typedef struct node{
struct node *left, *right;
int value;
}NODE, *P_NODE;
P_NODE initNode(P_NODE target);
void printNode(P_NODE target);
P_NODE init();
P_NODE addLeft(P_NODE target);
P_NODE addRight(P_NODE target);
void pre_re(P_NODE current);
void in_re(P_NODE current);
void post_re(P_NODE current);
void pre(P_NODE current);
void pre_f(P_NODE current);
void pre_lr(P_NODE current);
#endif
///////////////////////
//bt.c
///////////////////////
#include <stdio.h>
#include "stack.h"
#include "bt.h"
P_NODE root;
P_NODE initNode(P_NODE target){
target -> left = NULL;
target -> right = NULL;
target -> value = 0;
return target;
}
void printNode(P_NODE target){
printf("%p,%p,%d\n",target -> left, target -> right, target -> value);
}
P_NODE init(){
root = ((P_NODE)malloc(sizeof(NODE)));
//printNode(root);
initNode(root);
//printNode(root);
return root;
}
P_NODE addLeft(P_NODE target){
return initNode(target -> left = ((P_NODE)malloc(sizeof(NODE))));
}
P_NODE addRight(P_NODE target){
return initNode(target -> right = ((P_NODE)malloc(sizeof(NODE))));
}
void pre_re(P_NODE current){
if(current == NULL){
return;
}
printf("%d ", current -> value);
pre_re(current -> left);
pre_re(current -> right);
}
void in_re(P_NODE current){
if(current == NULL){
return;
}
in_re(current -> left);
printf("%d ", current -> value);
in_re(current -> right);
}
void post_re(P_NODE current){
if(current == NULL){
return;
}
post_re(current -> left);
post_re(current -> right);
printf("%d ", current -> value);
}
void pre(P_NODE current){
clear();
while(current != NULL || getPos() != -1){
if(current != NULL){
printf("%d ", current -> value);
push(current);
current = current -> left;
}else{
current = ((P_NODE)pop()) -> right;
}
}
clear();
}
void pre_f(P_NODE current){
if(current == NULL){
return;
}
clear();
push(current);
while(getPos() != -1){
printf("%d ", current -> value);
if(current -> right != NULL){
push(current -> right);
}
if(current -> left != NULL){
current = current -> left;
}else{
current = (P_NODE)pop();
}
}
clear();
}
void pre_lr(P_NODE current){
if(current == NULL){
return;
}
clear();
push(current);
while(getPos() != -1){
current = (P_NODE)pop();
printf("%d ", current -> value);
if(current -> right != NULL){
push(current -> right);
}
if(current -> left != NULL){
push(current -> left);
}
}
clear();
}
///////////////////////
//cc.c
///////////////////////
#include <stdio.h>
#include "bt.h"
extern P_NODE root;
int main(){
init();
P_NODE n1, n2, n3, n4, n5, n6;
n1 = root;
n1 -> value = 1;
n2 = addLeft(n1);
n2 -> value = 2;
n3 = addRight(n1);
n3 -> value = 3;
n4 = addLeft(n2);
n4 -> value = 4;
n5 = addRight(n2);
n5 -> value = 5;
n6 = addRight(n3);
n6 -> value = 6;
int n = 6;
void (*visitors[])(P_NODE current) = {pre_re, in_re, post_re, pre, pre_f, pre_lr};
int i;
for(i = 0; i < n; i++){
(visitors[i])(root);
printf("\n");
}
return 0;
}
分享到:
相关推荐
setting.xml文件,修改Maven仓库指向至阿里仓
基于java的玉安农副产品销售系统的开题报告
dev-c++ 6.3版本
基于java的项目监管系统开题报告
基于springboot多彩吉安红色旅游网站源码数据库文档.zip
毕业设计&课设_基于 AFLFast 改进能量分配策略的毕业设计项目,含 Mix Schedule策略设计及测试结果分析.zip
基于springboot办公用品管理系统源码数据库文档.zip
C++调用qml对象Demo
非常漂亮的类Web界面的Delphi设计54ed7-main.zip
VB SQL车辆管理系统是一款基于Visual Basic(VB)编程语言和SQL数据库开发的综合车辆管理工具。该系统集成了车辆信息管理、驾驶员信息管理、车辆调度、维修记录、数据存储与检索、报告生成以及安全权限管理等多个核心功能模块。 源代码部分提供了详细的开发流程和实现方法,涵盖了从数据库设计、界面设计到事件驱动编程、数据访问技术和错误处理等关键技术点。通过该系统,用户可以方便地录入、查询、修改和删除车辆及驾驶员信息,实现车辆信息的实时更新和跟踪。同时,系统还支持生成各类车辆管理相关的报告,帮助用户更好地掌握车辆运营情况。 系统部分则采用了直观易用的用户界面设计,使得用户能够轻松上手并快速完成车辆管理工作。系统还具备强大的数据处理能力和安全性,通过数据备份和系统升级优化等功能,确保数据的完整性和系统的稳定运行。 总体而言,VB SQL车辆管理系统是一款功能全面、易于操作且安全可靠的车辆管理工具,适用于企业和个人进行日常车辆运营和管理。无论是车辆信息的录入、查询还是报告生成,该系统都能够提供高效、便捷的服务,是车辆管理工作的理想选择。
AutoSAR基础学习资源
基于springboot英语学习平台源码数据库文档.zip
数据集,深度学习,密封数据集,马体态数据集
基于java的数字家庭网站开题报告
podman使用国内源镜像加速器
基于springboot+web的留守儿童网站源码数据库文档.zip
基于springboot的智能宾馆预定系统源码数据库文档.zip
GetQzonehistory-main.zip
环境说明:开发语言:Java 框架:springboot JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7 数据库工具:Navicat 开发软件:eclipse/myeclipse/idea Maven包:Maven 浏览器:谷歌浏览器。 项目经过测试均可完美运行
内容概要:本文档详细介绍了QST公司生产的QMI8A01型号的6轴惯性测量单元的数据表及性能参数。主要内容包括设备特性、操作模式、接口标准(SPI、I2C与I3C),以及各种运动检测原理和技术规格。文中还提到了设备的工作温度范围宽广,内置的大容量FIFO可用于缓冲传感器数据,减少系统功耗。此外,对于器件的安装焊接指导亦有详细介绍。 适合人群:电子工程技术人员、嵌入式开发人员、硬件设计师等。 使用场景及目标:适用于需要精准测量物体空间位置变化的应用场合,如消费电子产品、智能穿戴设备、工业自动化等领域。帮助工程师快速掌握该款IMU的技术要点和应用场景。 其他说明:文档提供了详细的电气连接图表、封装尺寸图解等资料,方便用户进行电路板的设计制作。同时针对特定应用提出了一些优化建议。