栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

求二叉树结点的个数

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

求二叉树结点的个数

#include
#include

typedef char ElemType;
typedef struct BTNode{
	ElemType data;
	struct BTNode *lchild;
	struct BTNode *rchild;
}BTNode,*BiTree;

void createBiTree(BTNode *&B)
{
	ElemType ch;
	scanf("%c",&ch);
	if(ch== ' ') B=NULL;
	else
	{
		B = (BTNode*)malloc(sizeof(BTNode));
		B->data = ch;
		createBiTree(B->lchild);
		createBiTree(B->rchild);
	}
}

int countNode(BiTree B)
{
	if(!B)
		return 0;
	else
		return 1 + countNode(B->lchild) + countNode(B->rchild);
}

void printPreOrder(BiTree B)
{
	if(B)
	{
		printf("%c ",B->data);
		printPreOrder(B->lchild);
		printPreOrder(B->rchild);
	}
}

void main()
{
	BiTree B;
	createBiTree(B);
	printf("先序遍历:");
	printPreOrder(B);
	printf("n");
	printf("结点个数:%dn",countNode(B));
}

按先序遍历来输入二叉树结点,若孩子结点为空,则输入空格。

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/528989.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号