Submission #727601

#TimeUsernameProblemLanguageResultExecution timeMemory
727601SanguineChameleonDuathlon (APIO18_duathlon)C++17
16 / 100
43 ms7108 KiB
#include <bits/stdc++.h> using namespace std; void just_do_it(); int main() { #ifdef KAMIRULEZ freopen("kamirulez.inp", "r", stdin); freopen("kamirulez.out", "w", stdout); #endif ios_base::sync_with_stdio(0); cin.tie(0); just_do_it(); return 0; } const int maxn = 1e5 + 20; vector<int> adj[maxn]; bool can[55][55][55]; bool bad[maxn]; bool flag[maxn]; int n, m; void dfs(int x, int a, int b) { can[x][a][b] = true; for (auto c: adj[b]) { if (c != x && !can[x][a][c]) { dfs(x, a, c); } } } void sub1() { for (int x = 1; x <= n; x++) { for (int a = 1; a <= n; a++) { if (a != x) { dfs(x, a, a); } } bad[x] = false; } int res = 0; for (int a = 1; a <= n; a++) { for (int b = 1; b <= n; b++) { if (b == a) { continue; } for (int c = 1; c <= n; c++) { if (c == a || c == b) { continue; } bool ok = true; for (int x = 1; x <= n; x++) { if (x == b) { continue; } if (!can[x][a][b] && !can[x][b][c]) { ok = false; break; } } if (ok) { res++; } } } } cout << res; } void just_do_it() { cin >> n >> m; for (int i = 0; i < m; i++) { int u, v; cin >> u >> v; adj[u].push_back(v); adj[v].push_back(u); } if (n <= 50) { sub1(); } }
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...