제출 #995775

#제출 시각아이디문제언어결과실행 시간메모리
995775aaaaaarroz축구 경기장 (IOI23_soccer)C++17
컴파일 에러
0 ms0 KiB
#include <bits/stdc++.h> using namespace std; bool limites(int N, int i, int j){ return i>=0&&i<N&&j>=0&&j<N; } int biggest_stadium(int N, vector<vector<int>> F){ int empty_cells=0; pair<int,int>arbol; for(int i=0;i<N;i++){ for(int j=0;j<N;j++){ if(F[i][j]==0){ empty_cells++; } } } bool si=true; for(int i=0;i<N;i++){ for(int j=0;j<N;j++){ if(F[i][j]==1){ continue; } priority_queue<tuple<int,int,int>,vector<tuple<int,int,int>>,greater<tuple<int,int,int>>>cola; int dx[]={1,0,-1,0}; int dy[]={0,1,0,-1}; vector<vector<int>>dist(N,vector<int>(N,INT_MAX)); dist[i][j]=0; cola.push({0,i,j}); while(!cola.empty()){ auto[d,x,y]=cola.top(); cola.pop(); for(int dir=0;dir<4;dir++){ int posi=x+dx[dir]; int posj=y+dy[dir]; while(true){ if(!limites(N,posi,posj)||F[posi][posj]==1)break; if((d+1)<dist[posi][posj]){ dist[posi][posj]=d+1; cola.push({dist[posi][posj],posi,posj}); } posi+=dx[dir]; posj+=dy[dir]; } } } for(int x=0;x<N;x++){ for(int y=0;y<N;y++){ if(F[x][y]==0&&(dist[x][y]>=3)){ si=false; } } } if(si){ return empty_cells; } else{ return 1; } } } } int main() { int N; cin>>N; vector<std::vector<int>> F(N, vector<int>(N)); for (int i = 0; i < N; i++) { for (int j = 0; j < N; j++) { cin>>F[i][j]; } } int res = biggest_stadium(N, F); cout<<res<<"\n"; return 0; }

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

soccer.cpp: In function 'int biggest_stadium(int, std::vector<std::vector<int> >)':
soccer.cpp:60:1: warning: control reaches end of non-void function [-Wreturn-type]
   60 | }
      | ^
/usr/bin/ld: /tmp/ccdI5DGF.o: in function `main':
grader.cpp:(.text.startup+0x0): multiple definition of `main'; /tmp/ccVig9PB.o:soccer.cpp:(.text.startup+0x0): first defined here
collect2: error: ld returned 1 exit status