Java | Leetcode Java题解之第222题完全二叉树的节点个数

题目:

题解:

java 复制代码
class Solution {
    public int countNodes(TreeNode root) {
        if (root == null) {
            return 0;
        }
        int level = 0;
        TreeNode node = root;
        while (node.left != null) {
            level++;
            node = node.left;
        }
        int low = 1 << level, high = (1 << (level + 1)) - 1;
        while (low < high) {
            int mid = (high - low + 1) / 2 + low;
            if (exists(root, level, mid)) {
                low = mid;
            } else {
                high = mid - 1;
            }
        }
        return low;
    }

    public boolean exists(TreeNode root, int level, int k) {
        int bits = 1 << (level - 1);
        TreeNode node = root;
        while (node != null && bits > 0) {
            if ((bits & k) == 0) {
                node = node.left;
            } else {
                node = node.right;
            }
            bits >>= 1;
        }
        return node != null;
    }
}
相关推荐
SimonKing15 小时前
Apache Commons Math3 使用指南:强大的Java数学库
java·后端·程序员
渣哥15 小时前
Java 集合迭代中的 fail-fast 与 fail-safe 机制详解
java
帧栈15 小时前
我的创作纪念日
java
bug攻城狮16 小时前
Spring Boot Banner
java·spring boot·后端
黑马源码库miui5208616 小时前
JAVA同城打车小程序APP打车顺风车滴滴车跑腿源码微信小程序打车源码
java·微信·微信小程序·小程序·uni-app
MadPrinter16 小时前
SpringBoot学习日记 Day11:博客系统核心功能深度开发
java·spring boot·后端·学习·spring·mybatis
淦出一番成就16 小时前
Java反序列化接收多种格式日期-JsonDeserialize
java·后端
Java中文社群16 小时前
Hutool被卖半年多了,现状是逆袭还是沉寂?
java·后端
爱吃苹果的日记本17 小时前
开学第一课
java
共享家952717 小时前
优先搜索(DFS)实战
算法·leetcode·深度优先