奇怪的电梯
题目描述
c大楼有一个一种很奇怪的电梯。大楼的每一层楼都可以停电梯,而且第 i 层楼 (1≤i≤N) 上有一个数字Ki(0≤Ki≤N)。电梯只有四个按钮:开,关,上,下。上下的层数等于当前楼层上的那个数字。当然,如果不能满足要求,相应的按钮就会失灵。例如:3,3,1,2,5 代表了Ki (K1=3,K2=3,…),在1楼,按“上”可以到4楼,按“下”是不起作用的,因为没有−2楼。那么,从A楼到B楼至少要按几次按钮呢?
输入格式:
第一行包含3个用空格隔开的正整数,分别表示N,A,B (1≤N≤200,1≤A,B≤N) 。 第二行包含N 个用空格隔开的非负整数,表示Ki 。
输出格式:
输出共一行,即最少按键次数,若无法到达,则输出 −1 。
输入样例:
5 1 5
3 3 1 2 5
输出样例
3
解题思路
利用bfs(广度优先搜索)来求解最短路问题
本题只有上下两个方向,如果是走迷宫类型一般为四个方向
代码
#include <iostream>
#include <queue>
using namespace std;
struct floor1
{
int x;
int y;
}f;
queue <floor1> q;
int main()
{
int n,a,