23972023-01-12 16:08:54TuruTamasTom és Jerry 3cpp11Hibás válasz 0/50768ms129732 KiB
#include <bits/stdc++.h>
using namespace std;

int T, N, Tom, Jerry, K;

#define vvig vector<vector<int>> &graph
#define vi vector<int>

void bfs(vector<int> &d, vvig, int kezd) {
    queue<int> q;
    q.push(kezd);
    d[kezd] = 0;
    int k;
    while (!q.empty())
    {
        k = q.front();
        q.pop();
        for (int x : graph[k]) {
            if (d[x] != -1) continue;
            d[x] = d[k] + 1;
            q.push(x);
        }
    }
}

void dfs_shortest_path(vvig, vi &path, int a, int &b, int dist, bool &end, vector<bool> &visited) {
    path.push_back(a);
    visited[a] = true;
    for (int x : graph[a]) {
        if (visited[x]) continue;
        if (end) {
            return;
        }
        if (x == b) {
            path.push_back(b);
            end = true;
        }
        else {
            dfs_shortest_path(graph, path, x, b, dist + 1, end, visited);
        }
    }
    if (!end) path.pop_back();
}

void dfs_visit(vector<bool> &visited, vvig, int a, vi &d) {
    visited[a] = true;
    for (int x: graph[a]) {
        if (visited[x] || d[x] <= K) continue;
        dfs_visit(visited, graph, x, d);
    }
}

void dfs_Jerry(vvig, vi d_tom, int loc, vector<bool> &visited, int dist, bool &success, bool &end) {
    visited[loc] = true;
    for (int x : graph[loc]) {
        if (end) return;
        if (visited[x] || d_tom[x] <= dist + 1) continue;
        if (d_tom[x] > K) {
            success = true;
            end = true;
            return;
        }
        dfs_Jerry(graph, d_tom, x, visited, dist + 1, success, end);
    }
}

int main() {
    cin >> T;
    for (size_t q = 0; q < T; q++)
    {
        cin >> N >> Tom >> Jerry >> K;
        Tom--; Jerry--;
        int a, b;
        
        vector<vi> graph(N);
        for (size_t i = 0; i < N - 1; i++)
        {
            cin >> a >> b;
            a--; b--;
            graph[a].push_back(b);
            graph[b].push_back(a);
        }
        
        vi d_tom(N, -1);
        bfs(d_tom, graph, Tom);

        bool success = false;
        {
        vector<bool> visited(N, false);
        bool end = false;
        dfs_Jerry(graph, d_tom, Jerry, visited, 0, success, end);
        }
        if (!success) cout << "IGEN";

        int max_d_tom = 0;        
        for (size_t i = 0; i < d_tom.size(); i++)
        {
            max_d_tom = d_tom[max_d_tom] < d_tom[i] ? i : max_d_tom;
        }
        
        vi d2(N, -1);
        bfs(d2, graph, max_d_tom);
        int max_d2 = 0;
        for (size_t i = 0; i < d_tom.size(); i++)
        {
            max_d2 = d2[max_d2] < d2[i] ? i : max_d2;
        }
        vi path;
        {
        bool end = false;
        vector<bool> visited(N, false);
        dfs_shortest_path(graph, path, max_d2, max_d_tom, 0, end, visited);
        }
        int middle = path[path.size()/2];

        vi d_middle(N, -1);

        bfs(d_middle, graph, middle);
        int counter = 0;
        vector<bool> visited(N, false);
        for (size_t i = 0; i < d_middle.size(); i++)
        {
            if (visited[i] || d_middle[i] <= K) continue;
            counter++;
            dfs_visit(visited, graph, i, d_middle);
        }
        if (counter >= 2) cout << "NEM\n";
        else cout << "IGEN\n";
        
    } // q (question)
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base0/50
1Hibás válasz0/03ms1936 KiB
2Hibás válasz0/02ms2032 KiB
3Hibás válasz0/52ms2116 KiB
4Hibás válasz0/14ms2204 KiB
5Hibás válasz0/14ms2472 KiB
6Hibás válasz0/14ms2604 KiB
7Hibás válasz0/14ms2812 KiB
8Hibás válasz0/14ms3008 KiB
9Hibás válasz0/14ms3216 KiB
10Hibás válasz0/14ms3544 KiB
11Hibás válasz0/24ms3552 KiB
12Hibás válasz0/24ms3680 KiB
13Hibás válasz0/14ms3920 KiB
14Hibás válasz0/2354ms19256 KiB
15Hibás válasz0/2533ms19964 KiB
16Időlimit túllépés0/2754ms28368 KiB
17Futási hiba0/2365ms129732 KiB
18Hibás válasz0/2535ms32456 KiB
19Hibás válasz0/2661ms15296 KiB
20Futási hiba0/297ms129680 KiB
21Hibás válasz0/2555ms26812 KiB
22Hibás válasz0/2268ms11136 KiB
23Időlimit túllépés0/3768ms54164 KiB
24Hibás válasz0/2499ms39132 KiB
25Hibás válasz0/3206ms18868 KiB
26Futási hiba0/2486ms129288 KiB
27Hibás válasz0/2324ms16488 KiB
28Hibás válasz0/3172ms7340 KiB