您的位置:首页 > 其它

51nod 1572 宝岛地图

2017-06-17 20:59 288 查看
预处理每个点,分别能往四个方向各走多少步。

#include<bits/stdc++.h>
using namespace std;

const int MAXN=1010;
const int MAXM=100100;

char mp[MAXN][MAXN];
int dp[4][MAXN][MAXN];
int chx[30],chy[30],suc[30];
char dir[MAXM];
int len[MAXM];

int main()
{
int n,m,i,j,k,flag,x,y;
while(~scanf("%d%d",&n,&m))
{
memset(chx,-1,sizeof(chx));
memset(chy,-1,sizeof(chy));
for(i=1;i<=n;i++)
for(j=1;j<=m;j++)
{
scanf(" %c",&mp[i][j]);
if(mp[i][j]>='A'&&mp[i][j]<='Z')
{
chx[mp[i][j]-'A']=i;
chy[mp[i][j]-'A']=j;
}
}
scanf("%d",&k);
for(i=0;i<k;i++)
{
scanf(" %c %d",&dir[i],&len[i]);
}
memset(dp,-1,sizeof(dp));
for(i=1;i<=n;i++)
{
for(j=1;j<=m;j++)
{
if(mp[i][j]!='#')
{
dp[0][i][j]=dp[0][i-1][j]+1;
dp[1][i][j]=dp[1][i][j-1]+1;
}
}
}
for(i=n;i>=1;i--)
{
for(j=m;j>=1;j--)
{
if(mp[i][j]!='#')
{
dp[2][i][j]=dp[2][i+1][j]+1;
dp[3][i][j]=dp[3][i][j+1]+1;
}
}
}
memset(suc,0,sizeof(suc));
for(i=0;i<26;i++)
{
if(chx[i]==-1)
continue;
flag=1;
x=chx[i];
y=chy[i];
for(j=0;j<k;j++)
{
if(dir[j]=='N')
{
if(len[j]<=dp[0][x][y])
x-=len[j];
else
{
flag=0;
break;
}
}
if(dir[j]=='W')
{
if(len[j]<=dp[1][x][y])
y-=len[j];
else
{
flag=0;
break;
}
}
if(dir[j]=='S')
{
if(len[j]<=dp[2][x][y])
x+=len[j];
else
{
flag=0;
break;
}
}
if(dir[j]=='E')
{
if(len[j]<=dp[3][x][y])
y+=len[j];
else
{
flag=0;
break;
}
}
}
if(flag)
suc[i]=1;
}
flag=0;
for(i=0;i<26;i++)
{
if(suc[i])
{
printf("%c",char(i+'A'));
flag=1;
}
}
if(!flag)
printf("no solution\n");
else
puts("");
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  51nod dp