POJ 1154 LETTERS dfs
http://poj.org/problem?id=1564
题意:从(0,0)开始,字母没走过的就可以走,问最多可以经过几个字母
一般的dfs,回溯
代码:
#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
#include<queue>
#define Max(a,b)a>b?a:b
using namespace std;
char map[22][22];
bool vs[22][22],v[30];
int R,C,ans;
int dir[4][2]={-1,0,1,0,0,1,0,-1};
void dfs(int x,int y,int step)
{
int k,p,np,nx,ny;
vs[x][y]=1;
p=map[x][y]-'A';
v[p]=1;
for(k=0;k<4;k++)
{
nx=x+dir[k][0];
ny=y+dir[k][1];
np=map[nx][ny]-'A';
if(nx<0||nx>=R||ny<0||ny>=C||vs[nx][ny]
||v[np])continue;
dfs(nx,ny,step+1);
}
ans=Max(ans,step);
vs[x][y]=0;
v[p]=0;
}
int main()
{
int i;
while(~scanf("%d%d",&R,&C))
{
for(i=0;i<R;i++)
{
getchar();
scanf("%s",map[i]);
}
memset(vs,0,sizeof(vs));
memset(v,0,sizeof(v));
ans=0;
dfs(0,0,1);
printf("%d\n",ans);
}
return 0;
}

浙公网安备 33010602011771号