最少转弯问题

最少转弯问题

题目描述

给出一张地图,这张地图被分为n*m(n,m≤100)个方块,任何一个方块不是平地就是高山。平地可以通过,高山则不能。现在你处在地图的(x1,y1)这块平地,问:你至少需要拐几个弯才能到达目的地(x2,y2)?你只能沿着水平和垂直方向的平地上行进,拐弯次数就等于行进方向的改变(从水平到垂直或从垂直到水平)次数。如右图,最少的拐弯次数为5。

输入

第1行:n m
第2至n+1行:整个地图地形描述(0:空地;1:高山),
第2行地形描述为:1 0 0 0 0 1 0
第3行地形描述为:0 0 1 0 1 0 0
……
第n+2行:x1 y1 x2 y2(分别为起点、终点坐标)

输出

S(即最少的拐弯次数)

样例输入

5  7
1  0  0  0  0  1  0
0  0  1  0  1  0  0
0  0  0  0  1  0  1
0  1  1  0  0  0  0
0  0  0  0  1  1  0
1  3  1  7

样例输出

5

提示

来源

广度优先搜索

信息

难度
9
分类
(无)
标签
(无)
递交数
3
已通过
1
通过率
33%
上传者

相关