TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) { stack<TreeNode*> stk; if (root) stk.push(root); while (!stk.empty()) { root = stk.top(); stk.pop(); if (root) { stk.push(root); stk.push(nullptr); if (root->right) stk.push(root->right); if (root->left) stk.push(root->left); } else { root = stk.top(); stk.pop(); if ((root->left == p &;;&;; root->right == q) || (root->left == q &;;&;; root->right == p)) return root; if (root == p &;;&;; (root->left == q || root->right == q)) return root; if (root == q &;;&;; (root->left == p || root->right == p)) return root; if (root->left == p || root->right == p) p = root; if (root->left == q || root->right == q) q = root; } } return nullptr; }
1

相关推荐

给个offer灞:校友 是不是金die
点赞 评论 收藏
分享
11-19 18:44
已编辑
成都理工大学 Java
程序员花海:我面试过100+校招生,大厂后端面试不看ACM,竞赛经历含金量低于你有几份大厂实习 这个简历整体来看不错 可以海投
如何写一份好简历
点赞 评论 收藏
分享
牛客网
牛客网在线编程
牛客网题解
牛客企业服务