Submission #760651

#TimeUsernameProblemLanguageResultExecution timeMemory
760651SanguineChameleonTropical Garden (IOI11_garden)C++17
100 / 100
61 ms24396 KiB
#include "garden.h" #include "gardenlib.h" #include <bits/stdc++.h> using namespace std; const int maxN = 1.5e5 + 20; vector<int> adj[maxN]; int nxt[maxN * 2]; int dist[maxN * 2][2]; int cnt[maxN * 2][2]; int cycle[2]; int dest; void dfs(int u, int k) { if (u == dest) { dist[u][k] = 0; return; } dist[u][k] = -2; int v = nxt[u]; if (dist[v][k] == -2) { dist[u][k] = -1; return; } else if (dist[v][k] == -3) { dfs(v, k); } if (dist[v][k] == -1) { dist[u][k] = -1; return; } else { dist[u][k] = dist[v][k] + 1; return; } } void count_routes(int N, int M, int P, int R[][2], int Q, int G[]) { for (int i = 0; i < M; i++) { int u = R[i][0]; int v = R[i][1]; adj[u].push_back(i << 1); adj[v].push_back(i << 1 | 1); } for (int i = 0; i < N; i++) { if ((int)adj[i].size() == 1) { nxt[adj[i][0] ^ 1] = adj[i][0]; } else { nxt[adj[i][0] ^ 1] = adj[i][1]; for (int j = 1; j < (int)adj[i].size(); j++) { nxt[adj[i][j] ^ 1] = adj[i][0]; } } } for (int k = 0; k < min(2, (int)adj[P].size()); k++) { dest = adj[P][k]; for (int i = 0; i < M * 2; i++) { dist[i][k] = -3; } for (int i = 0; i < M * 2; i++) { if (dist[i][k] == -3) { dfs(i, k); } } cycle[k] = (dist[nxt[dest]][k] == -1 ? -1 : dist[nxt[dest]][k] + 1); for (int i = 0; i < N; i++) { int start = adj[i][0]; if (dist[start][k] != -1) { cnt[dist[start][k]][k]++; } } if (cycle[k] != -1) { for (int i = cycle[k]; i < maxN * 2; i++) { cnt[i][k] += cnt[i - cycle[k]][k]; } } } for (int i = 0; i < Q; i++) { int res = 0; for (int k = 0; k < min(2, (int)adj[P].size()); k++) { if (cycle[k] == -1) { if (G[i] < maxN * 2) { res += cnt[G[i]][k]; } } else { int tmp = G[i]; if (G[i] >= maxN * 2) { G[i] -= ((G[i] - maxN * 2) / cycle[k] + 1) * cycle[k]; } res += cnt[G[i]][k]; G[i] = tmp; } } answer(res); } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...