王道p150 14.假设二叉树采用二叉链表存储结构,设计一个算法,求非空二叉树 b的宽度(即具有结点数最多的那一层的结点个数) (c语言代码实现)

采用层次遍历的方法求出所有结点的层次,并将所有结点和对应的层次放在一个队列中。然后通过扫描队列求出各层的结点总数,最大的层结点总数即为二叉树的宽度。

/* A

B C

D E F G */

本题代码如下

复制代码
int width(tree* t)
{
	quene q;
	tree p;
	int k;
	q.f = q.r = -1;//队列为空
	q.r++;
	q.data[q.r] = *t;//根结点进队
	q.level[q.r] = 1;//根结点层次为1
	while (q.f < q.r)
	{
		q.f++;//出队
		p = q.data[q.f];//出队结点
		k = q.level[q.f];//出队结点的层次
		if (p->lchild != NULL)//左孩子进队
		{
			q.r++;
			q.data[q.r] = p->lchild;
			q.level[q.r] = k + 1;
		}
		if (p->rchild != NULL)//右孩子进队
		{
			q.r++;
			q.data[q.r] = p->rchild;
			q.level[q.r] = k + 1;
		}
	}
	int max = 0;//保留同一层最多的结点个数
	int i = 0;//i扫描队中的所有元素
	k = 1;//k表示从第一层开始查找
	int n;//n统计第k层中的结点个数
	while (i <=q.r)
	{
		n = 0;
		while (i <=q.r && q.level[i] == k)//记录同一层有多少元素
		{
			n++;
			i++;
		}
		k = q.level[i];//将k等于下一层的层数
		if (n > max)//保留最大的n
			max = n;
	}
	return max;
}

完整测试代码

复制代码
#include<stdio.h>
#include<stdlib.h>
typedef struct treenode
{
	char data;
	struct treenode* lchild, * rchild;
}treenode,*tree;
typedef struct
{
	tree data[10];
	int level[10];
	int f, r;
}quene;
void buildtree(tree* t)
{
	char ch;
	ch = getchar();
	if (ch =='#')
		*t = NULL;
	else
	{
		*t = (treenode*)malloc(sizeof(treenode));
		(*t)->data = ch;
		(*t)->lchild = NULL;
		(*t)->rchild = NULL;
		buildtree(&(*t)->lchild);
		buildtree(&(*t)->rchild);
	}
}
int width(tree* t)
{
	quene q;
	tree p;
	int k;
	q.f = q.r = -1;//队列为空
	q.r++;
	q.data[q.r] = *t;//根结点进队
	q.level[q.r] = 1;//根结点层次为1
	while (q.f < q.r)
	{
		q.f++;//出队
		p = q.data[q.f];//出队结点
		k = q.level[q.f];//出队结点的层次
		if (p->lchild != NULL)//左孩子进队
		{
			q.r++;
			q.data[q.r] = p->lchild;
			q.level[q.r] = k + 1;
		}
		if (p->rchild != NULL)//右孩子进队
		{
			q.r++;
			q.data[q.r] = p->rchild;
			q.level[q.r] = k + 1;
		}
	}
	int max = 0;//保留同一层最多的结点个数
	int i = 0;//i扫描队中的所有元素
	k = 1;//k表示从第一层开始查找
	int n;//n统计第k层中的结点个数
	while (i <=q.r)
	{
		n = 0;
		while (i <=q.r && q.level[i] == k)//记录同一层有多少元素
		{
			n++;
			i++;
		}
		k = q.level[i];//将k等于下一层的层数
		if (n > max)//保留最大的n
			max = n;
	}
	return max;
}
int main()
{
	tree t;
	buildtree(&t);
	int widthnum = width(&t);
	printf("二叉树的宽度为:%d", widthnum);
	return 0;
}

用ABD##E##CF##G##测试

/* A

B C

D E F G */

相关推荐
董董灿是个攻城狮10 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
RuoZoe15 小时前
重塑WPF辉煌?基于DirectX 12的现代.NET UI框架Jalium
c语言
AI软著研究员17 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish17 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱18 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者1 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮1 天前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者1 天前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考1 天前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx2 天前
CART决策树基本原理
算法·机器学习