39152023-03-05 13:02:18zsomborKülönböző katicákcpp17Elfogadva 100/10087ms36760 KiB
#include <iostream>
#include <vector>
using namespace std;

int n;
bool lehet = true;
vector <vector <int>> g(1e5 + 1);
vector <int> f(1e5 + 1, 0);
vector <int> p(1e5 + 1, -1);
vector <int> mn(1e5 + 1, -1e9);
vector <int> mx(1e5 + 1, 1e9);
vector <int> par(1e5 + 1, -1);

void dfs1(int x) {
    if (p[x] > -1) {
        mn[x] = mx[x] = p[x];
        par[x] = p[x] % 2;
    }
    for (int i : g[x]) {
        dfs1(i);
        mn[x] = max(mn[x], mn[i] - 1);
        mx[x] = min(mx[x], mx[i] + 1);
        if (par[x] == -1 && par[i] > -1) par[x] = 1 - par[i];
        if (par[x] > -1 && par[i] > -1 && par[x] == par[i]) lehet = false;
    }
    if (mn[x] > mx[x]) lehet = false;
}

void dfs2(int x) {
    if (p[x] == -1) p[x] = (p[f[x]] + 1 <= mx[x] ? p[f[x]] + 1 : p[f[x]] - 1);
    for (int i : g[x]) dfs2(i);
}

int main()
{
    cin >> n;
    for (int i = 1; i <= n; i++) {
        cin >> f[i];
        g[f[i]].push_back(i);
    }
    for (int i = 1; i <= n; i++) cin >> p[i];
    dfs1(1);
    if (!lehet) { cout << "NEM"; return 0; }
    p[1] = (par[1] == -1 ? 0 : mn[1]);
    dfs2(1);
    cout << "IGEN\n";
    for (int i = 1; i <= n; i++) cout << p[i] << " ";
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva7ms10180 KiB
2Elfogadva6ms10452 KiB
3Elfogadva71ms14428 KiB
subtask210/10
4Elfogadva64ms14160 KiB
5Elfogadva68ms14848 KiB
6Elfogadva75ms15408 KiB
7Elfogadva81ms15748 KiB
subtask315/15
8Elfogadva71ms35800 KiB
9Elfogadva68ms35632 KiB
10Elfogadva87ms36760 KiB
11Elfogadva82ms36076 KiB
12Elfogadva82ms35296 KiB
13Elfogadva83ms36244 KiB
14Elfogadva78ms34840 KiB
subtask435/35
15Elfogadva7ms12488 KiB
16Elfogadva6ms12616 KiB
17Elfogadva6ms12700 KiB
18Elfogadva6ms12836 KiB
19Elfogadva6ms12780 KiB
20Elfogadva6ms12780 KiB
21Elfogadva6ms12912 KiB
22Elfogadva6ms12900 KiB
subtask540/40
23Elfogadva74ms16548 KiB
24Elfogadva65ms16680 KiB
25Elfogadva67ms16680 KiB
26Elfogadva75ms16552 KiB
27Elfogadva75ms16548 KiB
28Elfogadva82ms16680 KiB
29Elfogadva82ms16700 KiB
30Elfogadva79ms16836 KiB
31Elfogadva76ms16816 KiB
32Elfogadva81ms16924 KiB
33Elfogadva86ms16924 KiB