哀_心 2014-09-06 07:37
浏览 1108

poj3009题无法AC,但是测试数据对,如何解决

#include
int ans;
int dx[4]={1,0,-1,0},dy[4]={0,1,0,-1};
int m,n;
int square[30][30]={0};

void dfs(int x,int y,int step);

int main()
{
int i,j;
int p,q;
ans=12;
while(scanf("%d%d",&m,&n)!=EOF&&(m+n))
{
for(i=0;i<n;i++)
for(j=0;j<m;j++)
{
scanf("%d",&square[i][j]);
if(square[i][j]==2)
{
square[i][j]=0;
p=i;
q=j;
}
}
dfs(p,q,0);
if(ans<11)
printf("%d\n",ans);
else
printf("-1\n");
}
}

void dfs(int x,int y,int step)
{
int i,xx1,yy1,xx,yy;
if(step>10)
return;
for(i=0;i {
xx=x+dx[i];
yy=y+dy[i];
if(step=0&&xx=0&&yy {
while(xx>=0&&xx=0&&yy {
xx=xx+dx[i];
yy=yy+dy[i];
}
xx1=xx-dx[i];
yy1=yy-dy[i];
if(xx>=0&&xx=0&&yy<m)
{
if(square[xx][yy]==3)
ans=step+1;
else
{
square[xx][yy]=0;
dfs(xx1,yy1,step+1);
square[xx][yy]=1;
}
}
}
}
}

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
    • ¥15 求daily translation(DT)偏差订正方法的代码
    • ¥15 js调用html页面需要隐藏某个按钮
    • ¥15 ads仿真结果在圆图上是怎么读数的
    • ¥20 Cotex M3的调试和程序执行方式是什么样的?
    • ¥20 java项目连接sqlserver时报ssl相关错误
    • ¥15 一道python难题3
    • ¥15 牛顿斯科特系数表表示
    • ¥15 arduino 步进电机
    • ¥20 程序进入HardFault_Handler