제출 #84992

#제출 시각아이디문제언어결과실행 시간메모리
84992nikolapesic2802자리 배치 (IOI18_seats)C++14
컴파일 에러
0 ms0 KiB
#include <bits/stdc++.h> using namespace std; #define ll long long #define pb push_back int N; struct segTree{ vector<int> ones,tri; vector<int> sum; vector<pair<int,int> > minn; vector<int> num; void set(int i,int l,int r) { minn[i]=make_pair(0,0); num[i]=r-l+1; if(l==r) return; int m=(l+r)>>1; set(2*i,l,m); set(2*i+1,m+1,r); } void init() { ones.resize(4*N); tri.resize(4*N); minn.resize(4*N); num.resize(4*N); set(1,0,N-1); } void prop(int i) { if(ones[i]!=0){ ones[2*i]+=ones[i]; minn[2*i].first+=ones[i]; ones[2*i+1]+=ones[i]; minn[2*i+1].first+=ones[i]; ones[i]=0; } if(tri[i]!=0) { tri[2*i]+=tri[i]; minn[2*i].second+=tri[i]; tri[2*i+1]+=tri[i]; minn[2*i+1].second+=tri[i]; tri[i]=0; } } void update(int i) { if(minn[2*i]==minn[2*i+1]) { minn[i]=minn[2*i]; num[i]=num[2*i]+num[2*i+1]; return; } if(minn[2*i]<minn[2*i+1]) { minn[i]=minn[2*i]; num[i]=num[2*i]; return; } if(minn[2*i]>minn[2*i+1]) { minn[i]=minn[2*i+1]; num[i]=num[2*i+1]; } } void add(int qs,int qe,int x,int sta,int i=1,int l=0,int r=N-1) { //printf("%i %i %i %i %i %i %i\n",qs,qe,x,sta,i,l,r); if(qe<qs) return; if(r<qs||l>qe) return; if(qs<=l&&r<=qe) { if(sta==0){ ones[i]+=x; minn[i].first+=x; } else{ tri[i]+=x; minn[i].second+=x; } return; } int m=(l+r)>>1; prop(i); add(qs,qe,x,sta,2*i,l,m); add(qs,qe,x,sta,2*i+1,m+1,r); update(i); } int get() { //printf("%i %i\n",minn[1].first,minn[1].second); if(minn[1]==make_pair(4,0)) return num[1]; return 0; } } ST; vector<vector<int> > mat; int h,w; bool inside(int x,int y) { if(x>=0&&x<h&&y>=0&&y<w) return true; return false; } void update(int x,int y,int z) { vector<int> val; for(int i=0;i<2;i++) for(int j=0;j<2;j++) if(inside(x+i,y+j)) val.pb(mat[x+i][y+j]); sort(val.begin(),val.end()); if(val.size()==4) { ST.add(val[0],val[1]-1,z,0); ST.add(val[2],val[3]-1,z,1); return; //printf("Dodajem 1 od %i do %i, dodajem 3 od %i do %i\n",val[0],val[1]-1,val[2],val[3]-1); } if(val.size()==3) { assert(0); } if(val.size()==2) { ST.add(val[0],val[1]-1,z,0); return; //printf("Dodajem 1 od %i do %i\n",val[0],val[1]-1); } if(val.size()==1) { ST.add(val[0],N-1,z,0); //printf("Dodajem 1 od %i do %i\n",val[0],N-1); } } vector<int> r,c; vector<bool> sol; void give_initial_chart(int H, int W, std::vector<int> R, std::vector<int> C) { h=H; w=W; sol.resize(H*W); mat.resize(H); for(int i=0;i<H;i++) mat[i].resize(W); N=H*W; ST.init(); for(int i=0;i<H*W;i++){ mat[R[i]][C[i]]=i; r.pb(R[i]); c.pb(C[i]); } for(int i=-1;i<H;i++) { multiset<int> tr; if(i==-1) tr.insert(N); else tr.insert(mat[i][0]); tr.insert(N); tr.insert(N); if(i==H-1) tr.insert(N); else tr.insert(mat[i+1][0]); vector<int> val1; for(auto p:tr) { val1.pb(p); //printf("%i ",p); } //printf("\n"); ST.add(val1[0],val1[1]-1,1,0); ST.add(val1[2],val1[3]-1,1,1); //printf("Prosao!\n"); for(int j=0;j<W;j++) { vector<int> val; if(i!=-1&&i!=H-1) { if(j==0){ tr.erase(tr.find(N)); tr.erase(tr.find(N)); } else{ tr.erase(mat[i][j-1]); tr.erase(mat[i+1][j-1]); } if(j==W-1) { tr.insert(N); tr.insert(N); } else { tr.insert(mat[i][j+1]); tr.insert(mat[i+1][j+1]); } //val.clear(); for(auto p:tr) { val.pb(p); //printf("%i ",p); } //printf("\n"); ST.add(val[0],val[1]-1,1,0); ST.add(val[2],val[3]-1,1,1); } else { if(i!=H-1) { if(j==0){ tr.erase(tr.find(N)); } else{ tr.erase(mat[i+1][j-1]); } if(j==W-1) { tr.insert(N); } else { tr.insert(mat[i+1][j+1]); } //val.clear(); for(auto p:tr) { val.pb(p); //printf("%i ",p); } ST.add(val[0],val[1]-1,1,0); ST.add(val[2],val[3]-1,1,1); } else { //printf("zadnji!\n"); if(j==0){ tr.erase(tr.find(N)); } else{ tr.erase(mat[i][j-1]); } if(j==W-1) { tr.insert(N); } else { tr.insert(mat[i][j+1]); } //val.clear(); for(auto p:tr) { val.pb(p); //printf("%i ",p); } //printf("\n"); ST.add(val[0],val[1]-1,1,0); ST.add(val[2],val[3]-1,1,1); } } } } /*for(int i=-1;i<H;i++) for(int j=-1;j<W;j++) update(i,j,1);*/ //printf("%i\n",ST.get()); }

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

/tmp/ccWtS4uO.o: In function `main':
grader.cpp:(.text.startup+0x220): undefined reference to `swap_seats(int, int)'
collect2: error: ld returned 1 exit status