# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
83927 | nikolapesic2802 | Clickbait (COCI18_clickbait) | C++14 | 40 ms | 36052 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define pb push_back
const int N=1005;
vector<vector<pair<int,int> > > pipes(N);
int n,m;
vector<string> mat;
vector<vector<pair<int,pair<int,int> > > > container(N,vector<pair<int,pair<int,int> > >(N));
vector<vector<int> > pipe(N,vector<int>(N));
bool inside(int x,int y)
{
return x>=0&&x<n&&y>=0&&y<m;
}
void find_containers()
{
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
if(mat[i][j]=='+')
{
int x=i,y=j;
int rx,ry;
y++;
while(inside(x,y)&&mat[x][y]=='-')
y++;
if(!inside(x,y)||mat[x][y]!='+')
continue;
x++;
while(inside(x,y)&&mat[x][y]=='|')
x++;
if(!inside(x,y)||mat[x][y]!='+')
continue;
rx=x;ry=y;
y--;
while(inside(x,y)&&mat[x][y]=='-')
y--;
if(!inside(x,y)||mat[x][y]!='+')
continue;
x--;
while(inside(x,y)&&mat[x][y]=='|')
x--;
if(!inside(x,y)||mat[x][y]!='+'||x!=i||y!=j)
continue;
int c=0;
for(x=i+1;x<rx;x++)
{
for(y=j+1;y<ry;y++)
{
if(mat[x][y]!='.')
{
assert(c==0);
c=mat[x][y]-'0';
}
}
}
// printf("Nasao %i od %i %i do %i %i\n",c,i,j,rx,ry);
for(x=i;x<=rx;x++)
{
for(y=j;y<=ry;y++)
{
container[x][y].first=c;
container[x][y].second.first=i;
container[x][y].second.second=j;
}
}
}
}
}
}
void find_pipes()
{
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
if(mat[i][j]=='+'&&container[i][j].first==0&&!pipe[i][j])
{
//printf("Usao za %i %i\n",i,j);
vector<pair<int,int> > connect;
queue<pair<int,int> > q;
q.push({i,j});
pipe[i][j]=1;
while(!q.empty())
{
int x=q.front().first;
int y=q.front().second;
//printf("%i %i\n",x,y);
q.pop();
if(mat[x][y]=='.')
{
continue;
}
if(container[x][y].first!=0){
connect.pb({container[x][y].first,x-container[x][y].second.first});
continue;
}
for(int k=-1;k<2;k+=2)
{
if(inside(x+k,y)&&!pipe[x+k][y])
{
pipe[x+k][y]=1;
q.push({x+k,y});
}
if(inside(x,y+k)&&!pipe[x][y+k])
{
pipe[x][y+k]=1;
q.push({x,y+k});
}
}
}
assert(connect.size()==2);
if(connect[0].second!=0)
{
//printf("Dodajem iz %i u %i-%i\n",connect[0].first,N-connect[0].second,connect[1].first);
pipes[connect[0].first].pb({N-connect[0].second,connect[1].first});
}
else
{
//printf("Dodajem iz %i u %i-%i\n",connect[1].first,N-connect[1].second,connect[0].first);
pipes[connect[1].first].pb({N-connect[1].second,connect[0].first});
}
}
}
}
}
vector<int> solve(int tr)
{
vector<int> sol;
for(auto p:pipes[tr])
{
vector<int> s=solve(p.second);
for(auto d:s)
sol.pb(d);
}
sol.pb(tr);
return sol;
}
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cin >> n >> m;
mat.resize(n);
for(int i=0;i<n;i++)
cin >> mat[i];
find_containers();
find_pipes();
for(int i=0;i<N;i++)
{
sort(pipes[i].begin(),pipes[i].end());
}
vector<int> sol=solve(1);
for(auto p:sol)
printf("%i\n",p);
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |