cpp: add “2385. Amount of Time for Binary Tree to Be Infected”
Signed-off-by: Matej Focko <mfocko@redhat.com>
This commit is contained in:
parent
880aaa9179
commit
5f9d8d328b
1 changed files with 43 additions and 0 deletions
43
cpp/amount-of-time-for-binary-tree-to-be-infected.cpp
Normal file
43
cpp/amount-of-time-for-binary-tree-to-be-infected.cpp
Normal file
|
@ -0,0 +1,43 @@
|
|||
/**
|
||||
* Definition for a binary tree node.
|
||||
* struct TreeNode {
|
||||
* int val;
|
||||
* TreeNode *left;
|
||||
* TreeNode *right;
|
||||
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
|
||||
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
|
||||
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left),
|
||||
* right(right) {}
|
||||
* };
|
||||
*/
|
||||
class Solution {
|
||||
int dfs(TreeNode *root, int start, int &time) {
|
||||
if (root == nullptr) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
int left = dfs(root->left, start, time);
|
||||
int right = dfs(root->right, start, time);
|
||||
|
||||
if (root->val == start) {
|
||||
time = std::max(left, right);
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (left >= 0 && right >= 0) {
|
||||
return 1 + std::max(left, right);
|
||||
}
|
||||
|
||||
auto t = std::abs(left) + std::abs(right);
|
||||
time = std::max(time, t);
|
||||
|
||||
return std::min(left, right) - 1;
|
||||
}
|
||||
|
||||
public:
|
||||
int amountOfTime(TreeNode *root, int start) {
|
||||
int time = 0;
|
||||
dfs(root, start, time);
|
||||
return time;
|
||||
}
|
||||
};
|
Loading…
Reference in a new issue