假设二叉树采用二叉链表存储结构,设计一个算法,求非空二叉树b的宽度(即具有结点数最多的那一层的结点个数)。

题目描述:假设二叉树采用二叉链表存储结构,设计一个算法,求非空二叉树b的宽度(即具有结点数最多的那一层的结点个数)。

分析: 每次递归时,如果当前结点不为空,就将当前层数的宽度+1,并更新最大宽度。然后递归遍历左右子树,将层数加1。 最后最大宽度在全局变量 MAX 里。

c 复制代码
int MAX = -1;		//存放最大宽度
int width[100];	//每层的宽度
void Width(BiTree T,int k){    //k为层数,初始值为 0
	if(T == NULL)
		return;
	width[k]++;
	MAX = MAX < count[k] ? count[k] : MAX;
	Width(T->lchild,k + 1);
	Width(T->rchild,k + 1);
}
相关推荐
寄存器漫游者29 分钟前
数据结构 C语言 顺序栈
java·c语言·数据结构
日拱一卒——功不唐捐1 小时前
循环队列+双端队列(C语言)
c语言·数据结构
hnjzsyjyj1 小时前
洛谷 P3383:线性筛素数 ← 埃氏筛
数据结构·埃氏筛
80530单词突击赢1 小时前
STLVector底层原理与高效运用
数据结构·算法
haluhalu.2 小时前
LeetCode---基础算法刷题指南
数据结构·算法·leetcode
80530单词突击赢2 小时前
C++关联容器深度解析:set/map全攻略
java·数据结构·算法
_F_y2 小时前
链表:重排链表、合并 K 个升序链表、K 个一组翻转链表
数据结构·链表
XLYcmy2 小时前
一个用于统计文本文件行数的Python实用工具脚本
开发语言·数据结构·windows·python·开发工具·数据处理·源代码
方便面不加香菜2 小时前
数据结构--链式结构二叉树
c语言·数据结构
senijusene2 小时前
数据结构:单向链表(2)以及双向链表
数据结构·链表