# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
706470 | LittleCube | Magic Tree (CEOI19_magictree) | C++14 | 187 ms | 34060 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define ll long long
using namespace std;
int n, m, k, p[100005], d[100005], sz[100005];
ll w[100005];
vector<int> E[100005];
map<int, ll> mp[100005];
void dfs(int u)
{
sz[u] = 1;
for (int v : E[u])
{
dfs(v);
sz[u] += sz[v];
}
sort(E[u].begin(), E[u].end(), [&](int i, int j)
{ return sz[i] > sz[j]; });
for (int i = 0; i < E[u].size(); i++)
{
int v = E[u][i];
if (i == 0)
mp[u].swap(mp[v]);
else
{
for(auto [p, val] : mp[v])
mp[u][p] += val;
mp[v].clear();
}
}
if(w[u])
{
ll r = w[u];
mp[u][d[u]] += w[u];
auto iter = mp[u].upper_bound(d[u]);
while(r > 0 && iter != mp[u].end())
{
ll cur = iter->second;
if(r >= cur)
iter = mp[u].erase(iter);
else
iter->second -= r;
r -= cur;
}
}
}
signed main()
{
cin >> n >> m >> k;
for (int i = 2; i <= n; i++)
{
cin >> p[i];
E[p[i]].emplace_back(i);
}
for (int i = 1; i <= m; i++)
{
int v;
cin >> v;
cin >> d[v] >> w[v];
}
dfs(1);
ll ans = 0;
for(auto [p, v] : mp[1])
ans += v;
cout << ans << '\n';
}
컴파일 시 표준 에러 (stderr) 메시지
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |