Submission #257157

#TimeUsernameProblemLanguageResultExecution timeMemory
257157GREGOIRELCToy Train (IOI17_train)C++14
0 / 100
2088 ms1400 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]; bool dp[MAX_NOEUD]; vector<int> graphe[MAX_NOEUD]; vector<int> pile; vector<int> result; bool DFS(int curNoeud) { if(dp[curNoeud]) { for(int i = (int)pile.size() - 1; i > -1; i--) { if(estRechargeable[pile[i]]) { return true; } if(pile[i] == curNoeud) { return false; } } } dp[curNoeud] = true; pile.push_back(curNoeud); for(int voisin : graphe[curNoeud]) { bool val = DFS(voisin); if(!val && !estProprietaire[curNoeud]) { return false; } if(val && estProprietaire[curNoeud]) { return true; } } pile.pop_back(); dp[curNoeud] = false; return !estProprietaire[curNoeud]; } 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(DFS(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...