# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
622876 | CSQ31 | Airline Route Map (JOI18_airline) | C++17 | 0 ms | 0 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <cassert>
#include <cstdio>
#include <bits/stdc++.h>
using namespace std;
#define sz(a) (int)(a.size())
#define pb push_back
void Alice( int n, int m, int A[], int B[] ){
vector<array<int,2>>edge;
for(int i=0;i<m;i++){
edge.push_back({A[i],B[i]});
}
for(int i=0;i<n;i++){
for(int j=0;j<10;j++){
if(i&(1<<j)){
edge.push_back({i,j+n});
}
}
}
for(int j=0;j+1<10;j++)edge.push_back({j+n,j+n+1});
for(int j=0;j<10;j++){
edge.push_back({n+10,j+n});
edge.push_back({n+11,j+n});
}
InitG(n+12,sz(edge));
//cout<<vert<<" "<<M<<'\n';
int pos = 0;
for(auto x:edge)MakeG(pos++,x[0],x[1]);
}
bool vis[222222],mark[22222];
int lab[22222];
void Bob( int V, int U, int C[], int D[]){
//for(int i=0;i<U;i++)cout<<C[i]<<" "<<D[i]<<'\n';
vector<vector<int>>adj(V);
for(int i=0;i<U;i++){
adj[C[i]].pb(D[i]);
adj[D[i]].pb(C[i]);
}
for(int i=0;i<V;i++){
sort(adj[i].begin(),adj[i].end());
}
int n0 = 0,n1 = 0;
for(int i=0;i<V;i++){
for(int j=i+1;j<V;j++){
if(sz(adj[i]) != 10 || sz(adj[j])!=10)continue;
if(adj[i] == adj[j]){
n0 = i;
n1 = j;
break;
}
}
} //the ten bits
//cout<<"TES"<<'\n';
//cout<<n0<<" "<<n1<<'\n';
vector<int>bit;
for(int x:adj[n0]){
bit.pb(x);
mark[x] = 1;
}
int root = 0;
for(int i=0;i<10;i++){ //find a enpoint
int deg = 0;
for(int x:adj[bit[i]])deg+=mark[x];
if(deg==1)root = bit[i];
}
queue<int>q;
q.push(root);
vis[root] = 1;
vector<int>ord;
while(!q.empty()){
int v = q.front();
ord.pb(v);
q.pop();
for(int x:adj[v]){
if(!vis[x] && mark[x]){
vis[x] = 1;
q.push(x);
}
}
}
//for(int x:ord)cout<<x<<" ";
//cout<<'\n';
if(sz(adj[ord[0]]) < sz(adj[ord[9]]))reverse(ord.begin(),ord.end());
//wrong order
for(int i=0;i<V;i++){
if(mark[i] || i==n0 || i==n1)continue;
for(int x:adj[i]){
if(mark[x]){
for(int j=0;j<10;j++){
if(ord[j] ==x)lab[i]+=(1<<j);
}
}
}
}
vector<array<int,2>>edge;
for(int i=0;i<V;i++){
if(mark[i] || i==n0 || i==n1)continue;
for(int x:adj[i]){
if(mark[x] || x==n0 || x==n1)continue;
if(x > i)edge.pb({lab[i],lab[x]});
}
}
InitMap(V-12,sz(edge));
for(auto x:edge){
//MakeMap(x[0],x[1]);
//cout<<x[0]<<" "<<x[1]<<'\n';
}
for(auto x:edge){
MakeMap(x[0],x[1]);
//cout<<x[0]<<" "<<x[1]<<'\n';
}
}