HOJ---11491 A Knight and a Queen[超大数组+BFS]

 

A Knight and a Queen
Time Limit: 5000ms, Special Time Limit:12500ms, Memory Limit:32768KB
Total submit users: 52, Accepted users: 42
Problem 11491 : No special judgement
Problem description
Marge walks in the house and finds Homer staring at a chessboard with a knight and a queen on it.

Marge: Homer, are you OK? What’s up with these intellectual endeavors of yours recently?
Homer: Oh, I’m OK. And I’m not playing chess anyway.
Marge: So what are you doing?
Homer: I’m imagining that I’m a knight.
Marge: Yeah right.
Homer: Well, a knight sitting on the chessboard. And I imagine you are my queen.
Marge: I like that.
Homer: Of course you are sitting on the chessboard too. Now I wonder if I can reach the square you’re sitting on in 16 or fewer moves.
Marge: So can you?
Homer: I’m still trying to figure it out.

  Write a program that, when given a knight and a queen on an n by n chessboard, finds if the knight can reach the queen in m or fewer than moves. One ”move” for a knight is defined as 2 squares in one direction, then one square in a perpendicular direction. Knights cannot move along diagonals. For example, if n = 8, kx = 3, and ky = 5, then possible positions for the knight after one move given in (kx, ky) are: (1,6), (1,4), (2,7), (2,3), (4,7), (4,3), (5,6), and (5,4).
HOJ---11491 A Knight and a Queen[超大数组+BFS]



Input
For each test the input consists of 3 lines. The first line contains 2 numbers: n and m. n is the dimension of the board, and m is the number of moves the knight is allowed to do.
  The second line contains two numbers: kx and ky, s.t. 1 ≤ kx ≤ n, 1 ≤ ky ≤ n. These two numbers indicate the position of the knight on the board.
  The last line again contains two numbers: qx and qy, s.t. 1 ≤ qx ≤ n, 1 ≤ qy ≤ n. They indicate the position of the queen on the board.

Output
  If the queen is reachable by the knight with m or less moves, output should contain the following string on a single line ending with a newline:
Knight can reach Queen within m moves!

  If the queen is not reachable by the knight with m or less moves, output should contain the following string on a single line ending with a newline:
Knight cannot reach Queen within m moves!

  In the above, m should be the actual value from the input.   No test case will have the queen and the knight sitting on the same square. You can further assume that n ≤ 1000000,m ≤ 256. Your program should finish in less than one minute.

Sample Input
8 2

3 5

7 4



8 3

3 5

7 4
Sample Output
Knight cannot reach Queen within 2 moves!

Knight can reach Queen within 3 moves!
Problem Source
2008 Maryland High-school Programming Contest

 

 

 

 

因为数组大小很大,所以要把起点和终点平移,然后注意边界就好。

code:

  1 /*

  2 16 9

  3 15 2

  4 2 15

  5 Knight cannot reach Queen within 9 moves!

  6 16 10

  7 15 2

  8 2 15

  9 Knight can reach Queen within 10 moves!

 10 8 3

 11 4 2

 12 4 8

 13 Knight cannot reach Queen within 3 moves!

 14 1000000 256

 15 200000 800000

 16 800000 200000

 17 Knight cannot reach Queen within 256 moves!

 18 1000000 256

 19 350000 350000

 20 650000 650000

 21 Knight cannot reach Queen within 256 moves!

 22 384 256

 23 1 1

 24 384 384

 25 Knight can reach Queen within 256 moves!

 26 96 64

 27 1 1

 28 96 96

 29 Knight can reach Queen within 96 moves!

 30 */

 31 

 32 #include <iostream>   

 33 #include <iomanip>   

 34 #include <fstream>   

 35 #include <sstream>   

 36 #include <algorithm>   

 37 #include <string>   

 38 #include <set>   

 39 #include <utility>   

 40 #include <queue>   

 41 #include <stack>   

 42 #include <list>   

 43 #include <vector>   

 44 #include <cstdio>   

 45 #include <cstdlib>   

 46 #include <cstring>   

 47 #include <cmath>   

 48 #include <ctime>   

 49 #include <ctype.h> 

 50 using namespace std;

 51 

 52 int map[2000][2000];

 53 int vst[2000][2000];

 54 int n,m;

 55 int sx,sy,ex,ey;

 56 bool flag;

 57 int ledgex1,ledgey1,ledgex2,ledgey2;

 58 int dir[8][2]={

 59     2,1,

 60     1,2,

 61     -1,2,

 62     -2,1,

 63     -2,-1,

 64     -1,-2,

 65     1,-2,

 66     2,-1

 67 };

 68 

 69 struct node

 70 {

 71     int x,y;

 72     int step;

 73 }Node;

 74 

 75 bool check(int x,int y)

 76 {

 77     if(x>=(1000-ledgex1)&&x<(1000+n-ledgex1)&&y>=(1000-ledgey1)&&y<(1000+n-ledgey1)&&!vst[x][y])

 78         return true;

 79     else

 80         return false;

 81 }

 82 

 83 void bfs()

 84 {

 85     int i;

 86     node pre,last;

 87     pre.x=1000;

 88     pre.y=1000;

 89     pre.step=0;

 90     queue<node>Que;

 91     Que.push(pre);

 92     while(!Que.empty())

 93     {

 94         pre=Que.front();

 95         Que.pop();

 96         if(pre.step>m)

 97         {

 98             flag=false;

 99              return;

100         }

101         if(pre.x==ex&&pre.y==ey)

102         {

103             if(pre.step>m)

104                 flag=false;

105             return;

106         }

107         for(i=0;i<8;i++)

108         {

109             last.x=pre.x+dir[i][0];

110             last.y=pre.y+dir[i][1];

111             last.step=pre.step+1;

112             if(check(last.x,last.y))

113             {

114                 vst[last.x][last.y]=1;

115                 Que.push(last);

116             }

117         }

118     }

119 }

120 

121 int main()

122 {

123     while(~scanf("%d%d%d%d%d%d",&n,&m,&sx,&sy,&ex,&ey))

124     {

125         flag=true;

126         memset(vst,0,sizeof(vst));

127         if(abs(ex-sx)>m*2||abs(ey-sy)>m*2)

128             flag=false;

129         else

130         {

131             sx--;

132             ex--;

133             sy--;

134             ey--;

135             ledgex1=(sx>ex?ex:sx)>513?513:(sx>ex?ex:sx);

136             ledgey1=(sy>ey?ey:sy)>513?513:(sy>ey?ey:sy);

137             ex=ex-sx+1000;

138             ey=ey-sy+1000;

139             bfs();

140         }

141         if(flag)

142             printf("Knight can reach Queen within %d moves!\n",m);

143         else

144             printf("Knight cannot reach Queen within %d moves!\n",m);

145     }

146     return 0;

147 }

 

 

 

学长的代码,用了#include<map>

code2:

 1 #include <iostream>

 2 #include <queue>

 3 #include <map>

 4 using namespace std;

 5 

 6 struct node {

 7     int x,y,step;

 8     node () {

 9         x=y=step=0;

10     }

11 };

12 

13 int n,m,sx,sy,tx,ty,flag;

14 int dx[8]={-1,-2,-2,-1,1,2,2,1},dy[8]={-2,-1,1,2,2,1,-1,-2};

15 

16 void bfs()

17 {

18     if (abs(sx-tx)/2>m||abs(sy-ty)/2>m)

19         return;

20     queue<node> q;

21     map<pair<int, int>, int> v;

22     v.clear();

23     pair<int, int> b;

24     node cur,nex;

25     cur.x=sx;

26     cur.y=sy;

27     cur.step=0;

28     b.first=cur.x;

29     b.second=cur.y;

30     v[b]=1;

31     q.push(cur);

32     while (!q.empty()) {

33         cur=q.front();

34         q.pop();

35         if (cur.step>m)

36             continue;

37         if (cur.x==tx&&cur.y==ty&&cur.step<=m) {

38             flag=1;

39             return;

40         }

41         for (int i=0; i<8; i++) {

42             nex.x=cur.x+dx[i];

43             nex.y=cur.y+dy[i];

44             b.first=nex.x;

45             b.second=nex.y;

46             if (nex.x>=1&&nex.x<=n&&nex.y>=1&&nex.y<=n&&!v[b]) {

47                 nex.step=cur.step+1;

48                 v[b]=1;

49                 q.push(nex);

50             }

51         }

52     }

53 }

54 

55 int main()

56 {

57     while (~scanf("%d%d",&n,&m)) {

58         scanf("%d%d%d%d",&sx,&sy,&tx,&ty);

59         flag=0;

60         bfs();

61         if (flag)

62             printf("Knight can reach Queen within %d moves!\n",m);

63         else printf("Knight cannot reach Queen within %d moves!\n",m);

64     }

65     return 0;

66 }

 

 

 

 

 

你可能感兴趣的:(bfs)