0

0

c++中如何求二叉树节点个数_c++二叉树节点数量统计方法

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-09-26 10:44:01

|

751人浏览过

|

来源于php中文网

原创

答案是递归法最常用,定义TreeNode结构后,通过判断根节点是否为空,返回1加左右子树节点数之和,实现简洁高效。

c++中如何求二叉树节点个数_c++二叉树节点数量统计方法

在C++中统计二叉树的节点个数,最常用的方法是通过递归遍历整棵树。只要每个节点都被访问一次,就可以准确计数。

使用递归方式统计节点数量

从根节点开始,每遇到一个节点就加1,然后递归计算左子树和右子树的节点数之和。

定义二叉树节点结构:

struct TreeNode {
    int val;
    TreeNode* left;
    TreeNode* right;
    TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};

统计节点个数的递归函数

立即学习C++免费学习笔记(深入)”;

int countNodes(TreeNode* root) {
    if (root == nullptr) {
        return 0;
    }
    return 1 + countNodes(root->left) + countNodes(root->right);
}

说明:如果当前节点为空,返回0;否则返回1(当前节点)加上左右子树的节点总数。

使用迭代方式(层序遍历)统计

也可以用队列实现广度优先遍历,逐个访问节点并计数。

Bolt.new
Bolt.new

Bolt.new是一个免费的AI全栈开发工具

下载
#include 
int countNodesIterative(TreeNode* root) {
    if (root == nullptr) return 0;
std::queuezuojiankuohaophpcnTreeNode*youjiankuohaophpcn q;
q.push(root);
int count = 0;

while (!q.empty()) {
    TreeNode* node = q.front();
    q.pop();
    count++;

    if (node-youjiankuohaophpcnleft)  q.push(node-youjiankuohaophpcnleft);
    if (node-youjiankuohaophpcnright) q.push(node-youjiankuohaophpcnright);
}
return count;

}

说明:利用队列保存待访问的节点,每次出队一个节点就计数加1,并将其子节点入队。

适用于完全二叉树的优化方法

如果是完全二叉树,可以通过判断左右子树高度来减少递归调用,将时间复杂度优化到 O(log²n)。

基本思路:若左右子树高度相同,则左子树为满二叉树,可用公式计算节点数;否则右子树为满二叉树减去部分节点。

这种优化适用于特定场景,一般情况使用简单递归即可。

基本上就这些。普通二叉树推荐使用递归方法,代码简洁且易于理解。遇到特殊结构再考虑优化策略。

相关专题

更多
高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

4

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

3

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

10

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

33

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

15

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

42

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

7

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

9

2026.01.15

ppt一键生成相关合集
ppt一键生成相关合集

本专题整合了ppt一键生成相关教程汇总,阅读专题下面的的文章了解更多详细内容。

6

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.9万人学习

C 教程
C 教程

共75课时 | 4.1万人学习

C++教程
C++教程

共115课时 | 12.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号