题目描述
这有一个迷宫,有0~8行和0~8列:
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
0表示道路,1表示墙。
现在输入一个道路的坐标作为起点,再如输入一个道路的坐标作为终点,问最少走几步才能从起点到达终点?
(注:一步是指从一坐标点走到其上下左右相邻坐标点,如:从(3,1)到(4,1)。)
输入
第一行输入一个整数n(0<n<=100),表示有n组测试数据;
随后n行,每行有四个整数a,b,c,d(0<=a,b,c,d<=8)分别表示起点的行、列,终点的行、列。
输出
输出最少走几步。
样例输入
2 3 1 5 7 3 1 6 7
样例输出
12 11
#include<iostream>
using namespace std;
int min1 = 10000000;
int c = 0;
int h[4];
int a[4] = { -1, 0, 0, 1 };
int b[4] = { 0, 1, -1, 0 };
int map[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
};
bool judge(int x, int y)
{
if (0 <= x&&x <= 8 && 0 <= y&&y <= 8 && map[x][y] == 0)return true;
return false;
}
void dns(int x, int y)
{
if (x == h[2] && y == h[3])
{
if (c < min1)min1 = c;
}
else
{
for (int i = 0; i < 4; i++)
{
if (judge(x + a[i], y + b[i]))
{
map[x + a[i]][y + b[i]] = 1;
c++;
dns(x + a[i], y + b[i]);
map[x + a[i]][y + b[i]] = 0;
c--;
}
}
}
}
int main()
{
int n;
cin >> n;
for (int i = 0; i < n; i++)
{
cin >> h[0] >> h[1] >> h[2] >> h[3];
dns(h[0], h[1]);
cout << min1 << endl;
map[h[2]][h[3]] = 0;
c = 0;
min1 = 10000000;
}
return 0;
}