제출 #1029701

#제출 시각아이디문제언어결과실행 시간메모리
1029701sleepntsheep도시들 (IOI15_towns)C11
컴파일 에러
0 ms0 KiB
#include "towns.h" #include<string.h> #include<stdlib.h> #include<vector> int z; int left; int cache[120][120]; int l(int i, int j){return i<j?i:j;} int h(int i, int j){return i>j?i:j;} int getDistance2(int i,int j) { if(left--)return getDistance(i,j); exit(1); } int ask(int i, int j) { if(cache[i][j]>=0)return cache[i][j];return cache[i][j]=cache[j][i]=(i-j ? getDistance2(i, j): 0); } int argmax(int x, int N) { int mx = 0, dist = -1; for (int y, i = 0; i < N; ++i) if (dist < (y = ask(x, i))) dist = y, mx = i, z = dist; return mx; } #include<map> /* each branch store [arbitary node, branch length (to that node), count of leaves node in branch] */ int hubDistance(int N, int sub) { left=N*(N+1)/2; memset(cache,-1,sizeof cache); if (sub==1){ int d1 = argmax(0, N); int d2 = argmax(d1, N); int dd = z; int R = 1e9; for (int i = 0; i < N; ++i) { int a=ask(d1,i),b=ask(d2,i); int branch = (a+b-dd)/2; R=l(R,h(a,b)-branch); } return R; }else if(sub==3){ int d1 = argmax(0, N); int d2 = argmax(d1, N); int dd = z; for(int i=0;i<N;++i)for(int j=0;j<N;++j)ask(i,j); std::map<int,std::vector<std::array<int,3>>>M; int R = 1e9; for (int i = 0; i < N; ++i) { int a=ask(d1,i),b=ask(d2,i); int branch = (a+b-dd)/2; if(h(a,b)-branch<R){ M.clear(),R=h(a,b)-branch; M[a-branch].push_back(std::array<int,3>{i,branch, 1}); } else if(h(a,b)-branch==R){ int found=0; for(auto &x:M[a-branch]) if(ask(x[0],i)<branch+x[1]) /* same branch */ {++x[2];found=1;break;} if(!found) M[a-branch].push_back(std::array<int,3>{i,branch, 1}); }else; } for(auto &[_,branchinfo]:M){ int ok=1; for(auto&x:branchinfo)if(x[2]>(N/2))ok=0; if(ok)return R; } return -R; } }

컴파일 시 표준 에러 (stderr) 메시지

towns.c:5:9: fatal error: vector: No such file or directory
    5 | #include<vector>
      |         ^~~~~~~~
compilation terminated.