이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#pragma GCC optimize("Ofast")
using namespace std;
bitset <502> din[502][5005];
int sea[505][505];
char sal[5005],ch;
int sum,i,j,n,t,m,k;
int main()
{
ios_base :: sync_with_stdio(false);
cin.tie(0);
#ifdef HOME
ifstream cin("date.in");
ofstream cout("date.out");
#endif // HOME
cin>> n >> m >> t;
for (i=1;i<=n;i++)
{
for (j=1;j<=m;j++)
{
cin>>ch;
if (ch=='#')
{
sea[i][j]=0;
din[i][0][j]=0;
}
else
{
sea[i][j]=1;
din[i][0][j]=1;
}
}
}
cin>>(sal+1);
for (k=1;k<=t;k++)
{
for (i=1;i<=n;i++)
{
for (j=1;j<=m;j++)
{
if (sal[k]=='S')
{
din[i][k][j] = din[i-1][k-1][j] & sea[i][j];
}
else
if (sal[k]=='E')
{
din[i][k][j] = din[i][k-1][j-1] & sea[i][j];
}
else
if (sal[k]=='N')
{
din[i][k][j] = din[i+1][k-1][j] & sea[i][j];
}
else
if (sal[k]=='W')
{
din[i][k][j] = din[i][k-1][j+1] & sea[i][j];
}
else
{
din[i][k][j] = (din[i+1][k-1][j] | din[i][k-1][j-1] | din[i-1][k-1][j] | din[i][k-1][j+1] ) & sea[i][j];
}
}
}
}
for (i=1;i<=n;i++)
{
for (j=1;j<=m;j++)
{
sum=sum+din[i][t][j];
}
}
cout<<sum;
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |