完全二叉树的节点个数

Given the root of a complete binary tree, return the number of the nodes in the tree.

According to Wikipedia , every level, except possibly the last, is completely filled in a complete binary tree, and all nodes in the last level are as far left as possible. It can have between 1 and 2h nodes inclusive at the last level h.

Design an algorithm that runs in less than O(n) time complexity.

Example 1:

复制代码
Input: root = [1,2,3,4,5,6]
Output: 6

Example 2:

复制代码
Input: root = []
Output: 0

Example 3:

复制代码
Input: root = [1]
Output: 1

Constraints:

  • The number of nodes in the tree is in the range [0, 5 * 104].

  • 0 <= Node.val <= 5 * 104

  • The tree is guaranteed to be complete.

    class Solution {
    public:
    int countNodes(TreeNode* root) {
    if(root==NULL)return 0;
    TreeNodeleftNode=root->left;
    TreeNode
    rightNode=root->right;
    int leftDepth=0,rightDepth=0;
    while(leftNode){
    leftNode=leftNode->left;
    leftDepth++;
    }
    while(rightNode){
    rightNode=rightNode->right;
    rightDepth++;
    }
    if(leftDepth==rightDepth){
    return (2<<leftDepth)-1;
    }
    return countNodes(root->left)+countNodes(root->right)+1;//后序遍历的精简
    }
    };

思路:

1,计算完全二叉树节点的公式:满二叉树就可以直接2*2^depth-1

2,那问题来了,怎么判断是否为满二叉树呢?遍历得到左右两边的深度,leftDepth==rightDepth就是满二叉树(Ps:这种不是完全二叉树------完全二叉树除了最低级别的以外都是满的,尽可能满足左子树)

3,那如果不是满二叉树怎么求呢?------后序递归求得各个完全二叉子树的节点数相加,后+1(根节点)

相关推荐
AI进化营-智能译站4 分钟前
ROS2 C++开发系列16-智能指针管理传感器句柄|告别ROS2节点内存泄漏与野指针
java·c++·算法·ai
CS创新实验室38 分钟前
从盘边到芯端——硬盘接口七十年变迁史
算法·磁盘调度
xvhao20131 小时前
单源、多源最短路
数据结构·c++·算法·深度优先·动态规划·图论·图搜索算法
MATLAB代码顾问1 小时前
多种群协同进化算法(MPCE)求解大规模作业车间调度问题——附MATLAB代码
开发语言·算法·matlab
FQNmxDG4S1 小时前
JVM内存模型详解:堆、栈、方法区与垃圾回收
java·jvm·算法
We་ct2 小时前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·leetcode·typescript·动态规划
AI科技星2 小时前
精细结构常数α作为SI 7大基本量纲统一耦合常数的量子几何涌现理论
算法·机器学习·数学建模·数据挖掘·量子计算
txzrxz2 小时前
动态规划——背包问题
算法·动态规划
Yingye Zhu(HPXXZYY)2 小时前
洛谷 P15553 [CCPC 2025 哈尔滨站] 液压机
算法
谭欣辰3 小时前
LCS(最长公共子序列)详解
开发语言·c++·算法