Ai
1 Star 2 Fork 5

LilithSangreal/LeetCode-Solutions

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
count-complete-tree-nodes.cpp 1.28 KB
一键复制 编辑 原始数据 按行查看 历史
kamyu 提交于 2015-06-07 09:31 +08:00 . Update count-complete-tree-nodes.cpp
// Time: O(h * logn) = O((logn)^2)
// Space: O(1)
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
int countNodes(TreeNode* root) {
if (root == nullptr) {
return 0;
}
TreeNode *node = root;
int level = 0;
while (node->left != nullptr) {
node = node->left;
++level;
}
// Binary search.
int left = pow(2, level), right = pow(2, level + 1);
while (left < right) {
int mid = left + (right - left) / 2;
if (!exist(root, mid)) {
right = mid;
} else {
left = mid + 1;
}
}
return left - 1;
}
// Check if the nth node exist.
bool exist(TreeNode *root, int n) {
int k = 1;
while (k <= n) {
k <<= 1;
}
k >>= 2;
TreeNode *node = root;
while (k > 0) {
if ((n & k) == 0) {
node = node->left;
} else {
node = node->right;
}
k >>= 1;
}
return node != nullptr;
}
};
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/LilithSangreal/LeetCode-Solutions.git
git@gitee.com:LilithSangreal/LeetCode-Solutions.git
LilithSangreal
LeetCode-Solutions
LeetCode-Solutions
master

搜索帮助