C/C++语言实现数据结构系列(一)——二叉树及二叉树的基本操作(先序、中序、后序、构造)

#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<algorithm>
#define Status int
#define ERROR -1
#define OK 1
#define FALSE 0
#define MAXSIZE 30
using namespace std;
typedef struct Tree{
	int data;
	struct Tree* left;
	struct Tree* right;
}Tree,*BiTree;

void initTree(BiTree &tree){
	tree->left = NULL;
	tree->right = NULL;
}

//使用先序遍历构造二叉树 
Status createTree(BiTree &tree){
	int in;
	scanf("%d",&in);
	if(in == -1){
		tree = NULL;
	}else{
		tree = new Tree;
		tree->data = in;
		createTree(tree->left);
		createTree(tree->right);
	}
	return OK;
}
//访问二叉树中的节点信息 
void visit(BiTree tree){
	printf("%d\t",tree->data);
}
//先序遍历 
Status preOrder(BiTree tree){
	if(tree == NULL ){
		return ERROR;
	}
	visit(tree);
	preOrder(tree->left);
	preOrder(tree->right);
	return OK;
}
//非递归先序遍历 
void NnredursionPreorder(BiTree tree){
	int top = -1;
	BiTree data[MAXSIZE];
	while(top != -1 || tree!=NULL){
		if(tree!=NULL){
			printf("%d\t",tree->data);
			top++;
			data[top] = tree;
			tree = tree->left;
		}else{
			tree = data[top];
			top--;
			tree = tree->right;
		}
	}
	
} 
//中序遍历 
Status inOrder(BiTree tree){
	if(tree == NULL){
		return ERROR;
	}
	inOrder(tree->left);
	visit(tree);
	inOrder(tree->right);
	return OK;
}
//非递归中序遍历
void NnredursionInorder(BiTree tree){
	int top = -1;
	BiTree data[MAXSIZE];
	while(top != -1 || tree!=NULL){
		if(tree!=NULL){
			top++;
			data[top] = tree;
			tree = tree->left;
		}else{
			tree = data[top];
			printf("%d\t",tree->data);
			top--;
			tree = tree->right;
		}
	}
	
}  
//后序遍历 
Status postOrder(BiTree tree){
	if(tree == NULL){
		return ERROR;
	}
	postOrder(tree->left);
	postOrder(tree->right);
	visit(tree);
	return OK;
}
//层次遍历
Status levelOrder(BiTree tree){
	if(tree == NULL){
		return ERROR;
	}
	int top = 0,rear = 0;
	BiTree data[MAXSIZE];
	top = (top+1)%MAXSIZE;
	data[top] = tree;
	while(top != rear){
		BiTree node = data[(rear+1)%MAXSIZE];
		printf("%d\t",node->data);
		rear = (rear+1)%MAXSIZE;
		if(node->left != NULL){
			top = (top+1)%MAXSIZE;
			data[top] = node->left;
		}
		if(node->right != NULL){
			top = (top+1)%MAXSIZE;
			data[top] = node->right;
		}
	}
	return OK;
}

//树的深度 
int deepTree(BiTree tree){
	if(tree == NULL){
		return 0;
	}
	return max(deepTree(tree->left),deepTree(tree->right))+1;
}

//树的节点总数 
int getNodeNumber(BiTree tree){
	if(tree == NULL){
		return 0;
	}
	return getNodeNumber(tree->left) + getNodeNumber(tree->right) +1;
}

//树的叶子节点总数 
int getLeafNodeNumber(BiTree tree){
	if(tree == NULL){
		return 0;
	}
	if(tree->left == NULL && tree->right == NULL){
		return 1;
	}else{
		return getLeafNodeNumber(tree->left) + getLeafNodeNumber(tree->right);
	}
} 
int main(){
	BiTree tree = new Tree;
	initTree(tree);
	createTree(tree);
	//postOrder(tree);
	NnredursionPreorder(tree);
	printf("深度: %d\t",deepTree(tree));
	printf("节点总数: %d\t",getNodeNumber(tree));
	printf("叶子节点总数: %d",getLeafNodeNumber(tree));
} 
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

索半斤_suobanjin

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值