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

相关推荐
hsling松子2 小时前
使用PaddleHub智能生成,献上浓情国庆福
人工智能·算法·机器学习·语言模型·paddlepaddle
dengqingrui1232 小时前
【树形DP】AT_dp_p Independent Set 题解
c++·学习·算法·深度优先·图论·dp
C++忠实粉丝2 小时前
前缀和(8)_矩阵区域和
数据结构·c++·线性代数·算法·矩阵
ZZZ_O^O3 小时前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
CV-King3 小时前
opencv实战项目(三十):使用傅里叶变换进行图像边缘检测
人工智能·opencv·算法·计算机视觉
代码雕刻家3 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
雨中rain3 小时前
算法 | 位运算(哈希思想)
算法
Kalika0-05 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
代码雕刻家5 小时前
课设实验-数据结构-单链表-文教文化用品品牌
c语言·开发语言·数据结构
龙图:会赢的5 小时前
[C语言]--编译和链接
c语言·开发语言