-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdelete-nodes-and-return-forest.cpp
73 lines (55 loc) · 1.52 KB
/
delete-nodes-and-return-forest.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
* Copyright (c) 2018 Christopher Friedt
*
* SPDX-License-Identifier: MIT
*/
#include <unordered_set>
#include <vector>
using namespace std;
// https://leetcode.com/problems/delete-nodes-and-return-forest/
class Solution {
public:
vector<TreeNode *> delNodes(TreeNode *root, vector<int> &_to_delete) {
vector<TreeNode *> roots;
unordered_set<int> to_delete;
for (auto &d : _to_delete) {
to_delete.insert(d);
}
delNodesHelper(to_delete, roots, root, nullptr);
return roots;
}
protected:
void delNodesHelper(const unordered_set<int> &to_delete,
vector<TreeNode *> &roots, TreeNode *node,
TreeNode *parent) {
if (nullptr == node) {
return;
}
delNodesHelper(to_delete, roots, node->left, node);
delNodesHelper(to_delete, roots, node->right, node);
bool deleted = to_delete.end() != to_delete.find(node->val);
if (deleted) {
// clear this node's pointer from the parent node
if (nullptr != parent) {
if (parent->left == node) {
parent->left = nullptr;
} else {
parent->right = nullptr;
}
}
if (nullptr != node->left) {
roots.push_back(node->left);
node->left = nullptr;
}
if (nullptr != node->right) {
roots.push_back(node->right);
node->right = nullptr;
}
return;
}
if (nullptr == parent) {
// this is the root node and it hasn't been deleted
roots.push_back(node);
}
}
};