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("");
}
}
#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 1572宝岛地图(动态规划预处理+模拟)
- 51NOD 1572 宝岛地图(dp+优先队列)
- 51nod-1572-宝岛地图
- 51Nod - 1572 宝岛地图(模拟)
- 51nod 1572 宝岛地图 (预处理四个方向的最大步数优化时间,时间复杂度O(n*m+k))
- 51nod 1572 宝岛地图(思维)
- 51nod 1572 宝岛地图(前缀和)
- 51Nod-1572-宝岛地图
- 1572 宝岛地图【预处理+搜索】
- 宝岛地图 (51Nod-1572)
- 51nod 1572 宝岛地图
- 15nod1572-模拟&前缀和&枚举-宝岛地图
- 东北大炸弹 宝岛地图-枚举+数组记录+前缀和
- 宝岛地图(dp)
- 51nod1572 宝岛地图 预处理
- 知名iOS开发者郝培强打造《朋友地图》:将手机联系人标记到地图
- OpenStreetMap/Google/百度/Bing瓦片地图服务(TMS)
- 【51Nod】1289 - 大鱼吃小鱼(栈)
- Arcgis for Javascript实现两个地图的联动
- openlayer 系列二(地图切换控件)