Submission #223412

#TimeUsernameProblemLanguageResultExecution timeMemory
223412tqbfjotldMatching (COCI20_matching)C++14
18 / 110
2591 ms512 KiB
#include <bits/stdc++.h> using namespace std; #define MAX_N 2005 bool done[MAX_N]; int u[MAX_N],r[MAX_N], l[MAX_N],d[MAX_N]; int connect[MAX_N]; bool toret = false; int N; vector<pair<int,pair<int,int> > >c1; vector<pair<int,pair<int,int> > >c2; int X[MAX_N],Y[MAX_N]; void iterate(int n){ if (n==N){ printf("DA\n"); for (int x = 0; x<n; x++){ if (connect[x]!=-1){ printf("%d %d\n",x+1,connect[x]+1); } } toret = true; return; } if (u[n]!=-1){ bool can = true; for (auto x : c2){ if (X[n]<=x.second.second && X[n]>=x.second.first && x.first<=max(Y[n],Y[u[n]]) && x.first>=min(Y[n],Y[u[n]])){ can = false; break; } } if (can && !done[u[n]]){ connect[n] = u[n]; done[n] = true; done[u[n]] = true; int t = n+1; while (done[t]) t++; //printf("connect %d %d\n",n,u[n]); c1.push_back({X[n],{min(Y[n],Y[u[n]]),max(Y[n],Y[u[n]])}}); iterate(t); c1.pop_back(); connect[n] = -1; if (toret) return; done[n] = false; done[u[n]] = false; } } if (d[n]!=-1){ bool can = true; for (auto x : c2){ if (X[n]<=x.second.second && X[n]>=x.second.first && x.first<=max(Y[n],Y[d[n]]) && x.first>=min(Y[n],Y[d[n]])){ can = false; break; } } if (can && !done[d[n]]){ connect[n] = d[n]; done[n] = true; done[d[n]] = true; int t = n+1; while (done[t]) t++; //printf("connect %d %d\n",n,d[n]); c1.push_back({X[n],{min(Y[n],Y[d[n]]),max(Y[n],Y[d[n]])}}); iterate(t); c1.pop_back(); connect[n] = -1; if (toret) return; done[n] = false; done[d[n]] = false; } } if (r[n]!=-1){ bool can = true; for (auto x : c1){ if (Y[n]<=x.second.second && Y[n]>=x.second.first && x.first<=max(X[n],X[r[n]]) && x.first>=min(X[n],X[r[n]])){ can = false; break; } } if (can && !done[r[n]]){ connect[n] = r[n]; done[n] = true; done[r[n]] = true; int t = n+1; while (done[t]) t++; //printf("connect %d %d\n",n,r[n]); c2.push_back({Y[n],{min(X[n],X[r[n]]),max(X[n],X[r[n]])}}); iterate(t); c2.pop_back(); if (toret) return; connect[n] = -1; done[n] = false; done[r[n]] = false; } } if (l[n]!=-1){ bool can = true; for (auto x : c1){ if (Y[n]<=x.second.second && Y[n]>=x.second.first && x.first<=max(X[n],X[l[n]]) && x.first>=min(X[n],X[l[n]])){ can = false; break; } } if (can && !done[l[n]]){ connect[n] = l[n]; done[n] = true; done[l[n]] = true; int t = n+1; while (done[t]) t++; //printf("connect %d %d\n",n,l[n]); c2.push_back({Y[n],{min(X[n],X[l[n]]),max(X[n],X[l[n]])}}); iterate(t); c2.pop_back(); if (toret) return; connect[n] = -1; done[n] = false; done[l[n]] = false; } } } int main(){ memset(r,-1,sizeof(r)); memset(u,-1,sizeof(u)); memset(l,-1,sizeof(l)); memset(d,-1,sizeof(d)); memset(connect,-1,sizeof(connect)); int n; scanf("%d",&n); N=n; vector<pair<pair<int,int>,int> >v; vector<pair<pair<int,int>,int> > v2; for (int x = 0; x<n; x++){ int a,b; scanf("%d%d",&a,&b); v.push_back({{a,b},x}); v2.push_back({{b,a},x}); X[x] = a; Y[x] = b; } sort(v.begin(),v.end()); sort(v2.begin(),v2.end()); for (int x = 1; x<n; x++){ if (v[x].first.first==v[x-1].first.first){ int t1 = v[x].second; int t2 = v[x-1].second; u[t1] = t2; d[t2] = t1; } } for (int x = 1; x<n; x++){ if (v2[x].first.first==v2[x-1].first.first){ int t1 = v2[x].second; int t2 = v2[x-1].second; r[t1] = t2; l[t2] = t1;//printf("r %d %d\n",t1,t2); } } iterate(0); if (toret) return 0; printf("NE"); }

Compilation message (stderr)

matching.cpp: In function 'int main()':
matching.cpp:130:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%d",&n);
     ~~~~~^~~~~~~~~
matching.cpp:136:14: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d%d",&a,&b);
         ~~~~~^~~~~~~~~~~~~~
#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...