Submission #354552

#TimeUsernameProblemLanguageResultExecution timeMemory
354552Dilshod_ImomovStations (IOI20_stations)C++17
0 / 100
2 ms652 KiB
#include "stations.h" #include <bits/stdc++.h> using namespace std; const int N = 1e3 + 7; vector < int > adj[N]; std::vector<int> label(int n, int k, std::vector<int> u, std::vector<int> v) { std::vector<int> labels(n); for ( int i = 0; i < n; i++ ) { int x = u[i], y = v[i]; adj[x].push_back(y); adj[y].push_back(x); } vector < int > used(n + 1); int rt = -1; for ( int i = 0; i < n; i++ ) { if ( adj[i].size() == 1 && !used[i] ) { rt = i; break; } } int x = rt, num = 0; while ( 1 ) { labels[x] = num++; used[x] = 1; int ok = 1; for ( auto y: adj[x] ) { if ( !used[y] ) { x = y; ok = 0; break; } } if ( ok ) { break; } } return labels; } int find_next_station(int s, int t, std::vector<int> c) { if ( c.size() == 1 ) { return c[0]; } if ( s < t ) { return c[1]; } return c[0]; }
#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...