Ai
1 Star 2 Fork 5

LilithSangreal/LeetCode-Solutions

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
complete-binary-tree-inserter.cpp 1.23 KB
一键复制 编辑 原始数据 按行查看 历史
kamyu 提交于 2018-10-07 21:41 +08:00 . Create complete-binary-tree-inserter.cpp
// Time: ctor: O(n)
// insert: O(1)
// get_root: O(1)
// Space: O(n)
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class CBTInserter {
public:
CBTInserter(TreeNode* root) {
tree_.emplace_back(root);
for (int i = 0; i < tree_.size(); ++i) {
if (tree_[i]->left) {
tree_.emplace_back(tree_[i]->left);
}
if (tree_[i]->right) {
tree_.emplace_back(tree_[i]->right);
}
}
}
int insert(int v) {
auto n = tree_.size();
auto node = new TreeNode(v);
tree_.emplace_back(node);
if (n % 2) {
tree_[(n - 1) / 2]->left = node;
} else {
tree_[(n - 1) / 2]->right = node;
}
return tree_[(n - 1) / 2]->val;
}
TreeNode* get_root() {
return tree_[0];
}
private:
vector<TreeNode*> tree_;
};
/**
* Your CBTInserter object will be instantiated and called as such:
* CBTInserter obj = new CBTInserter(root);
* int param_1 = obj.insert(v);
* TreeNode* param_2 = obj.get_root();
*/
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/LilithSangreal/LeetCode-Solutions.git
git@gitee.com:LilithSangreal/LeetCode-Solutions.git
LilithSangreal
LeetCode-Solutions
LeetCode-Solutions
master

搜索帮助