王道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 */

相关推荐
INGNIGHT10 分钟前
984.不含 AAA 或 BBB 的字符串(贪心)
开发语言·算法·leetcode
代码中介商11 分钟前
哈希表:从O(1)查找到冲突解决全解析
数据结构·散列表
飞天狗11112 分钟前
2025第十六届蓝桥杯c/c++B组国赛题解
c语言·c++·算法·蓝桥杯
超梦dasgg18 分钟前
Tarjan算法解 强连通分量 & 循环依赖
算法·深度优先·图论
努力努力再努力wz24 分钟前
【Qt入门系列】:QLabel控件详解:从文本显示到图片展示,再到内容布局与伙伴机制
android·开发语言·数据结构·数据库·c++·qt·mysql
mN9B2uk1736 分钟前
MySQL命令行导出数据库
c语言·数据库·mysql
散峰而望40 分钟前
【算法练习】算法练习精选:从 Phone numbers 到 Decrease,覆盖字符串、模拟、图论思维题
数据结构·c++·算法·贪心算法·github·动态规划·图论
人道领域1 小时前
【LeetCode刷题日记】538.把二叉搜索树转换为累加树
java·开发语言·后端·算法·leetcode
并不喜欢吃鱼1 小时前
从零开始 C++----- 十二【C++ 数据结构】map/set 全解析:从使用到红黑树底层模拟实现
开发语言·数据结构·c++
zlinear数据采集卡1 小时前
电源纹波无处遁形!工业采集卡电源去耦与滤波电路深度解析
c语言·嵌入式硬件·fpga开发·自动化·硬件架构