제출 #1282520

#제출 시각아이디문제언어결과실행 시간메모리
1282520lmquanMagic Tree (CEOI19_magictree)C++20
100 / 100
1309 ms32952 KiB
#define taskname ""
#include <bits/stdc++.h>
using namespace std;

int main() {
  if (fopen(taskname".inp", "r")) {
    freopen(taskname".inp", "r", stdin);
    freopen(taskname".out", "w", stdout);
  }
  ios_base::sync_with_stdio(false);
  cin.tie(nullptr);

  int n, m, k;
  cin >> n >> m >> k;

  vector<vector<int>> children(n + 1);
  for (int i = 2; i <= n; i++) {
    int p;
    cin >> p;
    children[p].push_back(i);
  }
  vector<pair<int, int>> q(n + 1, {-1, -1});
  vector<int> s;
  for (int i = 1; i <= m; i++) {
    int v, d, w;
    cin >> v >> d >> w;
    q[v] = {d, w};
    s.push_back(d);
  }
  sort(s.begin(), s.end());
  s.erase(unique(s.begin(), s.end()), s.end());
  for (int i = 1; i <= n; i++) {
    if (q[i].first != -1) {
      q[i].first = upper_bound(s.begin(), s.end(), q[i].first) - s.begin();
    }
  }

  vector<multiset<pair<int, long long>>> d(n + 1);

  function<void(int)> DFS = [&](int u) {
    for (int v : children[u]) {
      DFS(v);
      if (d[u].size() < d[v].size()) {
        swap(d[u], d[v]);
      }
      for (auto i : d[v]) {
        auto it = d[u].lower_bound({i.first, 0});
        if (it == d[u].end() || (*it).first > i.first) {
          d[u].insert(i);
        } else {
          d[u].insert({it->first, it->second + i.second});
          d[u].erase(it);
        }
      }
      d[v].clear();
    }

    if (q[u].first != -1) {
      auto it = d[u].lower_bound({q[u].first - 1, 0});
      if (it == d[u].end() || it->first > q[u].first - 1) {
        d[u].insert({q[u].first - 1, 0});
        it = d[u].lower_bound({q[u].first - 1, 0});
      }
      d[u].insert({it->first, it->second + q[u].second});
      it = d[u].erase(it);
      it++;
      long long t = -q[u].second;
      while (true) {
        if (it == d[u].end()) {
          break;
        }
        pair<int, long long> x = *it;
        x.second += t;
        it = d[u].erase(it);
        if (x.second >= 0) {
          d[u].insert(x);
          break;
        }
        t = x.second, x.second = 0;
        d[u].insert(x);
      }
    }
  };

  int root = 1;
  DFS(root);

  long long result = 0;
  for (auto i : d[root]) {
    result += i.second;
  }
  cout << result;

  return 0;
}

컴파일 시 표준 에러 (stderr) 메시지

magictree.cpp: In function 'int main()':
magictree.cpp:7:12: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
    7 |     freopen(taskname".inp", "r", stdin);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~
magictree.cpp:8:12: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
    8 |     freopen(taskname".out", "w", stdout);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...