力扣222. 完全二叉树的节点个数

给你一棵完全二叉树 的根节点 root ,求出该树的节点个数。
完全二叉树 的定义如下:在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置。若最底层为第 h 层,则该层包含 1~ 2h 个节点。



提示:

  • 树中节点的数目范围是[0, 5 * 104]
  • 0 <= Node.val <= 5 * 104
  • 题目数据保证输入的树是 完全二叉树

进阶: 遍历树来统计节点是一种时间复杂度为 O(n) 的简单解决方案。你可以设计一个更快的算法吗?


代码:

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    int countNodes(TreeNode* root) {
        int cnt = 0;
        queue<TreeNode*> DS;
        
        if(root == nullptr) return 0;

        DS.push(root);
        cnt++;

        while(!DS.empty()){
            TreeNode* temp = DS.front();
            DS.pop();

            if(temp->right != nullptr){
                DS.push(temp->right);
                cnt++;
            }
            if(temp->left != nullptr){
                DS.push(temp->left);
                cnt++;
            }
        }

        return cnt;
    }
};

解题思路:

(1)使用广度优先搜索。

(2)使用队列保存节点,每插入一个节点,数量就+1。

相关推荐
7yewh2 小时前
【LeetCode】力扣刷题热题100道(26-30题)附源码 轮转数组 乘积 矩阵 螺旋矩阵 旋转图像(C++)
c语言·数据结构·c++·算法·leetcode·哈希算法·散列表
酒酿小圆子~4 小时前
NLP中常见的分词算法(BPE、WordPiece、Unigram、SentencePiece)
人工智能·算法·自然语言处理
huiyunfei5 小时前
MinorGC FullGC
java·jvm·算法
阿华写代码5 小时前
重新面试之JVM
jvm·面试·职场和发展
弓.长.6 小时前
【leetcode刷题】:双指针篇(有效三角形的个数、和为s的两个数)
c++·算法·leetcode
生信与遗传解读7 小时前
XGBoost算法在自定义数据集中预测疾病风险
人工智能·python·算法·数据分析
这辈子秃头是不可能的7 小时前
OpenGL利用DDA算法绘制图形,并增加鼠标键盘交互
算法·计算机外设·交互
Luo_LA8 小时前
【LeetCode Hot100 贪心算法】 买卖股票的最佳时机、跳跃游戏、划分字母区间
leetcode·游戏·贪心算法
疯狂飙车的蜗牛9 小时前
工作生活的感悟
嵌入式硬件·程序人生·职场和发展·感悟
小胖学前端10 小时前
如何运行一个Ink节点:从安装到监控的全方位指南
算法