제출 #117696

#제출 시각아이디문제언어결과실행 시간메모리
117696Plurm장난감 기차 (IOI17_train)C++14
0 / 100
12 ms1664 KiB
#include "train.h" #include <bits/stdc++.h> using namespace std; vector<int> g[5005]; vector<int> rg[5005]; bool found[5005]; stack<int> ord; void dfs1(int u){ if(found[u]) return; found[u] = true; for(int v : g[u]){ dfs1(v); } ord.push(u); } int cc[5005]; int memcnt[5005]; int ememcnt[5005]; bool gcc[5005]; void dfs2(int u, int c = 0){ if(!found[u]) return; found[u] = false; cc[u] = c; memcnt[c]++; for(int v : rg[u]){ dfs2(v, c); } } bool loop[5005]; vector<int> who_wins(vector<int> a, vector<int> r, vector<int> u, vector<int> v) { // Subtask 4 int m = u.size(); for(int i = 0; i < m; i++){ g[u[i]].push_back(v[i]); rg[v[i]].push_back(u[i]); if(u[i] == v[i]) loop[u[i]] = true; } int n = a.size(); for(int i = 0; i < n; i++){ dfs1(i); } int cccnt = 0; while(!ord.empty()){ int cur = ord.top(); ord.pop(); if(found[cur]) dfs2(cur, cccnt++); } for(int i = 0; i < m; i++){ if(cc[u[i]] == cc[v[i]]){ ememcnt[cc[u[i]]]++; } } vector<int> res; for(int i = 0; i < n; i++){ if(r[i]){ gcc[cc[i]] = memcnt[cc[i]] > 1 || loop[i]; } } for(int i = 0; i < n; i++){ bool ok = false; if(memcnt[cc[i]] == 1){ if(r[i]) ok = loop[i]; }else if(memcnt[cc[i]] == ememcnt[cc[i]]){ if(gcc[cc[i]]) ok = true; }else{ ok = r[i]; } res.push_back(ok); } return res; }
#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...