求二叉树的高度

思路

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

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

相关推荐
坫鹏加油站23 分钟前
【Python】支持向量机SVM
python·算法·机器学习·支持向量机
向日葵的小屋39 分钟前
csp知识基础——贪心算法
算法·贪心算法
百度Geek说1 小时前
百度智能云x中科大脑:「城市智能体」如何让城市更会思考
算法
霖002 小时前
FPGA的PS基础1
数据结构·人工智能·windows·git·算法·fpga开发
幸幸子.3 小时前
LeetCode 组合总数
c++·算法·leetcode
☆璇3 小时前
【C++】哈希
c++·算法·哈希算法
Warren983 小时前
Java Record 类 — 简化不可变对象的写法
java·开发语言·jvm·分布式·算法·mybatis·dubbo
数据智能老司机4 小时前
图算法趣味学——桥和割点
数据结构·算法·云计算
菜就多练,以前是以前,现在是现在4 小时前
Codeforces Round 1042 (Div. 3)
c++·算法
数据智能老司机6 小时前
图算法趣味学——图遍历
数据结构·算法·云计算