제출 #257088

#제출 시각아이디문제언어결과실행 시간메모리
257088GREGOIRELC장난감 기차 (IOI17_train)C++14
5 / 100
13 ms1280 KiB
#include "train.h" #include <iostream> using namespace std; const int MAX_NOEUD = 5e3; const int MAX_ARC = 2e4; int nbNoeud, nbArc; bool estProprietaire[MAX_NOEUD]; bool estRechargeable[MAX_NOEUD]; vector<int> graphe[MAX_NOEUD]; vector<int> result; bool estPossible(int noeudDepart) { int curNoeud = noeudDepart; bool nxtPossible = true; bool curPossible = false; while(nxtPossible) { nxtPossible = false; curPossible = false; for(int voisin : graphe[curNoeud]) { if(voisin == curNoeud + 1) { nxtPossible = true; } if(voisin == curNoeud) { curPossible = true; } } if(curPossible && !estProprietaire[curNoeud] && !estRechargeable[curNoeud]) { return false; } if(curPossible && estProprietaire[curNoeud] && estRechargeable[curNoeud]) { return true; } if(!nxtPossible && curPossible) { return estRechargeable[curNoeud]; } curNoeud++; } return false; } vector<int> who_wins(vector<int> a, vector<int> r, vector<int> u, vector<int> v) { nbNoeud = (int)a.size(); nbArc = (int)u.size(); for(int iNoeud = 0; iNoeud < nbNoeud; iNoeud++) { if(a[iNoeud] == 1) { estProprietaire[iNoeud] = true; } if(r[iNoeud]) { estRechargeable[iNoeud] = true; } } for(int iArc = 0; iArc < nbArc; iArc++) { graphe[u[iArc]].push_back(v[iArc]); } for(int iDep = 0; iDep < nbNoeud; iDep++) { if(estPossible(iDep)) { result.push_back(1); } else { result.push_back(0); } } return result; }
#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...