暑假小训练 (一道 不能不会的用结构体搜索题)

7 篇文章 2 订阅

http://acm.hust.edu.cn/vjudge/contest/129524#problem/I


题意:8x8的象棋,给出开始和结束的点,和一个不能走的点,求出最短路。


#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>

using namespace std;

int ax,ay,bx,by,cx,cy;
int gragh[10][10];
int path[10][10];

class Map       //用结构体可以方便的判断x,y
{
public:
    int x,y;
}now;

void bfs()
{
    now.x = ax;
    now.y = ay;

    queue<Map>q;
    q.push(now);

    while(!q.empty()){

        Map  a = q.front();
        q.pop();
        if(a.x == bx && a.y == by)
            return ;
        for(int i = -1;i <= 1; i++)
            for(int j = -1;j <= 1; j++)
                if(i != 0 || j != 0){
                    if(a.x+i <= 8 && a.x+i >= 1 && a.y+j <= 8 && a.y+j >= 1 && gragh[a.x+i][a.y+j] != -1 && path[a.x+i][a.y+j] == 0)
                    {       //分别判断了:界,不是c点,没走过
                        Map temp;
                        temp.x = a.x+i;
                        temp.y = a.y+j;
                        path[temp.x][temp.y] = path[a.x][a.y]+1;
                        q.push(temp);
                    }
                }
    }

}

int main()
{
    int ncase = 1;
//    freopen("in.txt","r",stdin);
    while(scanf("%d%d%d%d%d%d",&ax,&ay,&bx,&by,&cx,&cy) != EOF){
        memset(path,0,sizeof(path));
        memset(gragh,0,sizeof(gragh));  //记得初始化
        gragh[cx][cy] = -1;

        bfs();
        printf("Case %d: %d\n",ncase++,path[bx][by]);
    }
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值