NYOJ-58 最小步数 AC


#include<stdio.h>

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

int d[4][2] = {{1,0},{-1,0},{0,1},{0,-1}};

int mg[9][9]={1,1,1,1,1,1,1,1,1,
              1,0,0,1,0,0,1,0,1,
              1,0,0,1,1,0,0,0,1,
              1,0,1,0,1,1,0,1,1,
              1,0,0,0,0,1,0,0,1,
              1,1,0,1,0,1,0,0,1,
              1,1,0,1,0,1,0,0,1,
              1,1,0,1,0,0,0,0,1,
              1,1,1,1,1,1,1,1,1,};
               
int sx,sy,ex,ey,min=100000;

int main(){
	
	int n;
	
	scanf("%d",&n);
	
	while(n--){
	
		scanf("%d %d %d %d",&sx,&sy,&ex,&ey);
		
		if((sx == ex)&&(sy == ey)){
			printf("0\n");
			continue;
		}
		
		mg[sx][sy]=1;
		mg[ex][ey]=3;
	
		dfs(0,sx,sy);
			
		printf("%d\n",min);
	
		min=100000;
		mg[ex][ey]=0;
		mg[sx][sy]=0;
		
	}
	return 0;
}

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

	for(i = 0 ; i < 4; i++)
    {
        int k =x+d[i][0] , v = y+d[i][1] ;

        if(!mg[k][v]){
        	
        	mg[k-d[i][0]][v-d[i][1]] = 1;
        	
        	dfs(step+1 , k , v) ;
        	
        	mg[k-d[i][0]][v-d[i][1]] = 0;
        }
        
        if(mg[k][v] == 3)
            {
                if(step+1 < min)
                    min = step + 1;
            }
            
    }
}

终于,终于,终于,把这题目搞定了,居然只是0步的情况没有考虑到,哎

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值