求二叉树的高度

思路

利用二叉树的结构特点和递归思路,先求出左树高度和右树高度,较高的子树 + 1(根节点也占了一个高度单位)就是本树的高度。

代码

代码1,严重的计算重复问题

cpp 复制代码
int TreeHeight(BTNode* root)
{
	if (root == NULL)
		return 0;

	return TreeHeight(root->left) > TreeHeight(root->right)
		? TreeHeight(root->left) + 1 : TreeHeight(root->right) + 1;
}

比较时计算了一遍,返回时又计算了一遍,更可怕的是每颗子树都有这样的问题,虽然代码简单,但重复问题非常严重。

代码2,记录结果,避免重复计算

cpp 复制代码
int TreeHeight(BTNode* root)
{
	if (root == NULL)
		return 0;

	int leftHeight = TreeHeight(root->left);
	int rightHeight = TreeHeight(root->right);

	return leftHeight > rightHeight ? leftHeight + 1 : rightHeight + 1;
}

比较时计算了一遍,这时把结果记录到变量里,返回时直接使用变量返回,没有重复计算。

代码3,fmax函数

cpp 复制代码
int TreeHeight(BTNode* root)
{
	if (root == NULL)
		return 0;

	return fmax(TreeHeight(root->left), TreeHeight(root->right)) + 1;
}

实参完成计算过程,传递给形参,形参直接用作返回,计算过程不重复。

相关推荐
像污秽一样几秒前
算法设计与分析-习题4.5
数据结构·算法·排序算法·剪枝
样例过了就是过了10 分钟前
LeetCode热题100 全排列
数据结构·c++·算法·leetcode·dfs
2401_8980751211 分钟前
分布式系统监控工具
开发语言·c++·算法
程序员夏末17 分钟前
【LeetCode | 第六篇】算法笔记
笔记·算法·leetcode
OKkankan34 分钟前
撕 STL 系列:封装红黑树实现 mymap 和 myset
java·c++·算法
xh didida39 分钟前
数据结构--实现链式结构二叉树
c语言·数据结构·算法
ab15151740 分钟前
3.15二刷基础90、105、106、110
数据结构·c++·算法
C蔡博士40 分钟前
最近点对问题(Closest Pair of Points)
java·python·算法
白太岁42 分钟前
算法:链表:指针变化与环
数据结构·算法·链表
寻寻觅觅☆42 分钟前
东华OJ-进阶题-10-分解质因数(C++)
数据结构·c++·算法