Submission #439069

#TimeUsernameProblemLanguageResultExecution timeMemory
439069flappybirdToy Train (IOI17_train)C++17
11 / 100
11 ms1708 KiB
#include "train.h" #include <bits/stdc++.h> #pragma GCC optimize("O3") #pragma GCC optimize("Ofast") #pragma GCC optimize("unroll-loops") #pragma GCC target("avx,avx2,fma") using namespace std; typedef int ll; #define MAX 6000 vector<ll> A, s; ll N, M; vector<ll> adj[MAX], rev[MAX], deg, d; ll mp[MAX][MAX]; std::vector<int> who_wins(std::vector<int> a, std::vector<int> r, std::vector<int> u, std::vector<int> v) { ll i; A = a; N = a.size(); M = u.size(); d.resize(N); deg.resize(N); vector<ll> res; res.resize(N); for (i = 0; i < N; i++) if (r[i]) s.push_back(i); for (i = 0; i < M; i++) adj[u[i]].push_back(v[i]), rev[v[i]].push_back(u[i]), d[u[i]]++; deg = d; for (auto st : s) { ll j; queue<ll> q; q.push(st); res[st] = 1; while (!q.empty()) { ll t = q.front(); q.pop(); for (auto x : rev[t]) { if (res[x]) continue; deg[x]--; if (a[x]) q.push(x), res[x] = 1; else if (deg[x] <= 0) q.push(x), res[x] = 1; } } } //impossible vector<ll> imp; for (i = 0; i < N; i++) if (!res[i]) imp.push_back(i); deg = d; res.clear(); res.resize(N); for (auto st : imp) { ll j; queue<ll> q; q.push(st); res[st] = 1; while (!q.empty()) { ll t = q.front(); q.pop(); for (auto x : rev[t]) { if (res[x]) continue; deg[x]--; if (!a[x]) q.push(x), res[x] = 1; else if (deg[x] <= 0) q.push(x), res[x] = 1; } } } for (i = 0; i < N; i++) res[i] = !res[i]; return res; }

Compilation message (stderr)

train.cpp: In function 'std::vector<int> who_wins(std::vector<int>, std::vector<int>, std::vector<int>, std::vector<int>)':
train.cpp:32:6: warning: unused variable 'j' [-Wunused-variable]
   32 |   ll j;
      |      ^
train.cpp:54:6: warning: unused variable 'j' [-Wunused-variable]
   54 |   ll j;
      |      ^
#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...