hdu 1372 bfs Knight Moves

題目  http://acm.hdu.edu.cn/showproblem.php?pid=1372

這是一個簡單的搜索問題    題目意思是   一隻馬從一個點到另外一個點就可以了   你要知道象棋中馬是怎麼走的。

其他的就可以了,剛開始做這個題目的時候 ,由於標記數組爲mark[9][9]   但是我在初始化的時候

for(int i=0;i<=9;i++)
     for(int j=0;j<=9;j++)
     {
         mark[i][j]=0;
     }

一直錯了  就是不知道爲什麼  呵呵     所以一定要小心哦。。。

ac  代碼

#include<iostream>
#include<cstdio>
#include<queue>
using namespace std;
struct node{
int x,y,num;};///num 步數

char s[5],s1[5];
int sx,sy,ex,ey,mark[9][9];
int dre[8][2]={1,2,1,-2,2,1,2,-1,-1,2,-1,-2,-2,1,-2,-1}; ///2,1,2,-1,-2,1,-2,-1,1,2,1,-2,-1,2,-1,-2
///馬走的座標

void bfs()
{
     for(int i=0;i<9;i++)  ///標記初始化
     for(int j=0;j<9;j++)
     {
         mark[i][j]=0;
     }

    queue<node> Q;
    node p,t;
    p.x=sx;
    p.y=sy;
    p.num=0;

   // int sum=0;
    mark[sx][sy]=1;
    Q.push(p);

    while(!Q.empty())
    {
        t=Q.front();
        Q.pop();

        if(t.x==ex&&t.y==ey)  ///是否到達目的地
        {
             cout<<"To get from "<<s<<" to "<<s1<<" takes "<<t.num<<" knight moves."<<endl;
             return ;
        }

        for(int i=0;i<8;i++)  ///馬可以從8個方向走
        {
            p=t;
            p.x+=dre[i][0];
            p.y+=dre[i][1];
            ///是否在棋盤裏面
            if(p.x>=0&&p.x<8&&p.y>=0&&p.y<8&&!mark[p.x][p.y])
            {
                mark[p.x][p.y]=1;
                p.num+=1;
                Q.push(p);
            }
        }
    }
}

int main()
{

    while(scanf("%s %s",s,s1)!=EOF)
    {
        sy=s[0]-'a',sx=s[1]-'1';  ///這樣x,y的座標
        ey=s1[0]-'a',ex=s1[1]-'1';

        if(sx==ex&&sy==ey)
        {
            cout<<"To get from "<<s<<" to "<<s1<<" takes 0 knight moves."<<endl;
            continue;
        }

        bfs();

    }
    return 0;
}


 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章