求二叉树的高度

思路

利用二叉树的结构特点和递归思路,先求出左树高度和右树高度,较高的子树 + 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;
}

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

相关推荐
WBluuue12 分钟前
Codeforces 1087 Div2(ABCDEF)
c++·算法
Yzzz-F37 分钟前
2025 ICPC武汉邀请赛 G [根号分治 容斥原理+DP]
算法
abant242 分钟前
leetcode 114 二叉树变链表
算法·leetcode·链表
tankeven44 分钟前
HJ165 小红的优惠券
c++·算法
先积累问题,再逐次解决1 小时前
快速幂优美算法
算法
XiYang-DING1 小时前
【LeetCode】 225.用队列实现栈
算法·leetcode·职场和发展
花月C2 小时前
线性动态规划(Linear DP)
算法·动态规划·代理模式
hetao17338372 小时前
2025-03-24~04-06 hetao1733837 的刷题记录
c++·算法
_深海凉_2 小时前
LeetCode热题100-环形链表
算法·leetcode·链表