Submission #465727

#TimeUsernameProblemLanguageResultExecution timeMemory
465727AmirElarbiSenior Postmen (BOI14_postmen)C++14
0 / 100
1095 ms25280 KiB
#include <bits/stdc++.h> #define vi vector<int> #define ve vector #define ll long long #define vf vector<float> #define vll vector<pair<ll,ll>> #define ii pair<int,int> #define vvi vector<vi> #define vii vector<ii> #define gii greater<ii> #define pb push_back #define fi first #define se second #define INF 1e7 #define unsigned u #define eps 1e-18 #define eps1 1e-25 #define optimise ios_base::sync_with_stdio(false);cin.tie(NULL); #define MAX_A 100005 #define V 450 #define re register #define maxi(a,b) ((a) > (b) ? (a) : (b)) using namespace std; set<int> adj[500005]; bool vis[500005]; int n,m,used; bool dfs(int u, int p, int start){ vis[u] = 1; for(auto x : adj[u]) { //cout << adj[u].size() << endl; if(x == p) continue; if(x == start) { //cout << used << " " << m << endl; adj[u].erase(x); adj[x].erase(u); used++; if(used == m) return true; for (int i = 1; i <= n; ++i) { //cout << i << endl; memset(vis, 0, sizeof vis); if(dfs(i,-1,i)){ cout << i << endl; return true; } } used--; adj[u].insert(x); adj[x].insert(u); return false; } if(vis[x]) continue; used++; adj[u].erase(x); adj[x].erase(u); if(dfs(x,u,start)){ cout << x << " "; return true; } used--; adj[u].insert(x); adj[x].insert(u); } return false; } int main(){ optimise; cin >> n >> m; for (int i = 0; i < m; ++i) { int a,b; cin >> a >>b; adj[a].insert(b); adj[b].insert(a); } for (int i = 1; i <= n; ++i) { memset(vis, 0, sizeof vis); used = 0; if(dfs(i,-1,i)){ cout << i; return 0; } } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...