Submission #107602

# Submission time Handle Problem Language Result Execution time Memory
107602 2019-04-25T09:49:26 Z SYCstudio Airline Route Map (JOI18_airline) C++14
Compilation error
0 ms 0 KB
#include "Alicelib.h"
#include<cstdio>
#include<vector>
#include<algorithm>
#include<iostream>
#include<cmath>
using namespace std;

#define pb push_back
#define mp make_pair
#define ft first
#define sd second
static const int maxN=1024;
static const int BIT=10;//warning
static vector<pair<int,int> > E;

void Alice(int N,int M,int A[],int B[]){
    //cout<<"N:"<<N<<" "<<M<<endl;
    for (int i=0;i<M;i++) E.pb(mp(A[i],B[i]));
    for (int i=0;i<N;i++){
	E.pb(mp(i,N+BIT));
	for (int j=0;j<BIT;j++)
	    if (i&(1<<j)) E.pb(mp(i,N+j));
    }
    for (int i=1;i<BIT;i++) E.pb(mp(N+i-1,N+i));
    for (int i=2;i+1<BIT;i++) E.pb(mp(N,N+i));
    for (int i=0;i<BIT;i++) E.pb(mp(N+i,N+BIT)),E.pb(mp(N+i,N+BIT+1));

    //for (int i=0;i<E.size();i++) cout<<E[i].ft<<" "<<E[i].sd<<endl;

    InitG(N+BIT+2,(int)(E.size()));
    for (int i=0,sz=E.size();i<sz;i++) MakeG(i,E[i].ft,E[i].sd);
    return;
}

#include "Boblib.h"
#include<cstdio>
#include<algorithm>
#include<cstdlib>
#include<iostream>
#include<cmath>
using namespace std;

#define mp make_pair
#define ft first
#define sd second
static const int maxN=1020;
static const int BIT=10;//warning!

static vector<int> E[maxN];
static int Mark[maxN],Id[maxN],scnt,BS[BIT+10];

static bool cmps(int a,int b);
void Bob(int V,int U,int C[],int D[]){
    for (int i=0;i<U;i++) E[C[i]].push_back(D[i]),E[D[i]].push_back(C[i]);
    //cout<<"BOB:"<<endl;
    //for (int i=0;i<U;i++) cout<<C[i]<<" "<<D[i]<<endl;
    //for (int i=0;i<V;i++) cout<<E[i].size()<<" ";cout<<endl;
    int mrt=0;for (int i=0;i<V;i++) if (E[i].size()>E[mrt].size()) mrt=i;
    Mark[mrt]=-1;
    for (int i=0,sz=E[mrt].size();i<sz;i++) Mark[E[mrt][i]]=1;
    int id12=0;while (Mark[id12]) ++id12;

    pair<int,int> Seq[BIT+10];
    for (int i=0,sz=E[id12].size();i<sz;i++) Mark[E[id12][i]]=2,Seq[scnt++]=mp(0,E[id12][i]);
    for (int i=0;i<BIT;i++){
	int u=Seq[i].sd;
	for (int j=0,sz=E[u].size();j<sz;j++) if (Mark[E[u][j]]==2) ++Seq[i].ft;
    }
    //for (int i=0;i<BIT;i++) cout<<"("<<Seq[i].sd<<" "<<Seq[i].ft<<")";cout<<endl;
    //cout<<"scnt:"<<scnt<<endl;
    int bitone=0;
    for (int i=1;i<BIT;i++) if (Seq[i].ft>Seq[bitone].ft) bitone=i;
    bitone=Seq[bitone].sd;
    for (int i=0,u=bitone,sz=E[u].size();i<sz;i++) if (Mark[E[u][i]]==2) Mark[E[u][i]]=3;

    BS[BIT]=-1;
    for (int i=0;i<BIT;i++) if (Mark[Seq[i].sd]==2&&Seq[i].sd!=bitone) BS[BIT-1]=Seq[i].sd;
    for (int i=BIT-1;i>=2;i--){
	int u=BS[i];
	for (int j=0,sz=E[u].size();j<sz;j++){
	    int v=E[u][j];
	    if (Mark[v]==3&&v!=bitone&&v!=BS[i+1]){
		BS[i-1]=v;break;
	    }
	}
    }
    BS[0]=bitone;
    //cout<<"BS:";for (int i=0;i<BIT;i++) cout<<BS[i]<<" ";cout<<endl;

    for (int i=0;i<BIT;i++){
	int u=BS[i];
	for (int j=0,sz=E[u].size();j<sz;j++) if (Mark[E[u][j]]==1) Id[E[u][j]]|=(1<<i);
    }

    int mcnt=0;for (int i=0;i<U;i++) if (Mark[C[i]]==1&&Mark[D[i]]==1) ++mcnt;
    //cout<<"mcnt:"<<mcnt<<endl;
    //for (int i=0;i<V;i++) cout<<Id[i]<<" ";cout<<endl;
    InitMap(V-BIT-2,mcnt);
    for (int i=0;i<U;i++) if (Mark[C[i]]==1&&Mark[D[i]]==1) MakeMap(Id[C[i]],Id[D[i]]);
    
    return;
}

Compilation message

Bob.cpp:15:8: error: 'vector' does not name a type; did you mean 'wctob'?
 static vector<int> E[maxN];
        ^~~~~~
        wctob
Bob.cpp: In function 'void Bob(int, int, int*, int*)':
Bob.cpp:20:27: error: 'E' was not declared in this scope
     for (int i=0;i<U;i++) E[C[i]].push_back(D[i]),E[D[i]].push_back(C[i]);
                           ^
Bob.cpp:24:41: error: 'E' was not declared in this scope
     int mrt=0;for (int i=0;i<V;i++) if (E[i].size()>E[mrt].size()) mrt=i;
                                         ^
Bob.cpp:26:21: error: 'E' was not declared in this scope
     for (int i=0,sz=E[mrt].size();i<sz;i++) Mark[E[mrt][i]]=1;
                     ^
Bob.cpp:30:21: error: 'E' was not declared in this scope
     for (int i=0,sz=E[id12].size();i<sz;i++) Mark[E[id12][i]]=2,Seq[scnt++]=mp(0,E[id12][i]);
                     ^
Bob.cpp:33:18: error: 'E' was not declared in this scope
  for (int j=0,sz=E[u].size();j<sz;j++) if (Mark[E[u][j]]==2) ++Seq[i].ft;
                  ^
Bob.cpp:40:30: error: 'E' was not declared in this scope
     for (int i=0,u=bitone,sz=E[u].size();i<sz;i++) if (Mark[E[u][i]]==2) Mark[E[u][i]]=3;
                              ^
Bob.cpp:46:18: error: 'E' was not declared in this scope
  for (int j=0,sz=E[u].size();j<sz;j++){
                  ^
Bob.cpp:58:18: error: 'E' was not declared in this scope
  for (int j=0,sz=E[u].size();j<sz;j++) if (Mark[E[u][j]]==1) Id[E[u][j]]|=(1<<i);
                  ^
Bob.cpp: At global scope:
Bob.cpp:18:13: warning: 'bool cmps(int, int)' declared 'static' but never defined [-Wunused-function]
 static bool cmps(int a,int b);
             ^~~~