aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2021-03-09 16:56:59 +0800
committercrupest <crupest@outlook.com>2021-03-09 16:56:59 +0800
commit2768b3fc1d7e6232ff703b6ac3a05b52745a4f97 (patch)
tree26c9f72cedf98534efd1a128590adeebf12746d6
parent5242b780d8c6aee430bc4a655679ddd5814016b9 (diff)
downloadcrupest-2768b3fc1d7e6232ff703b6ac3a05b52745a4f97.tar.gz
crupest-2768b3fc1d7e6232ff703b6ac3a05b52745a4f97.tar.bz2
crupest-2768b3fc1d7e6232ff703b6ac3a05b52745a4f97.zip
import(solutions): Add problem 1220.
-rw-r--r--works/solutions/acwing/1220.cpp65
1 files changed, 65 insertions, 0 deletions
diff --git a/works/solutions/acwing/1220.cpp b/works/solutions/acwing/1220.cpp
new file mode 100644
index 0000000..443ed43
--- /dev/null
+++ b/works/solutions/acwing/1220.cpp
@@ -0,0 +1,65 @@
+#include <iostream>
+#include <vector>
+
+const int N = 100010;
+
+struct Node {
+ int w;
+ std::vector<int> children;
+};
+
+int n;
+Node nodes[N];
+bool visited[N];
+long long contain_root[N];
+long long contain_or_not_contain_root[N];
+
+void dfs(int i) {
+ visited[i] = true;
+ long long this_contain_root = nodes[i].w;
+ long long this_contain_or_not_contain_root = nodes[i].w;
+
+ for (auto next : nodes[i].children) {
+ if (!visited[next]) {
+ dfs(next);
+ if (contain_root[next] > 0) {
+ this_contain_root += contain_root[next];
+ }
+ if (contain_or_not_contain_root[next] >
+ this_contain_or_not_contain_root) {
+ this_contain_or_not_contain_root = contain_or_not_contain_root[next];
+ }
+ }
+ }
+
+ if (this_contain_root > this_contain_or_not_contain_root) {
+ this_contain_or_not_contain_root = this_contain_root;
+ }
+
+ contain_root[i] = this_contain_root;
+ contain_or_not_contain_root[i] = this_contain_or_not_contain_root;
+}
+
+int main() {
+ std::ios_base::sync_with_stdio(false);
+ std::cin.tie(nullptr);
+
+ std::cin >> n;
+
+ for (int i = 1; i <= n; i++) {
+ std::cin >> nodes[i].w;
+ }
+
+ for (int i = 1; i < n; i++) {
+ int a, b;
+ std::cin >> a >> b;
+ nodes[a].children.push_back(b);
+ nodes[b].children.push_back(a);
+ }
+
+ dfs(1);
+
+ std::cout << contain_or_not_contain_root[1];
+
+ return 0;
+}