bfs例题 strange lift 结果老是-1,不知道怎么错的。。。求高手解答(我是菜鸟,老被虐)

weir_007 2012-07-16 06:52:49
//strange lift

#include<iostream>
#include<queue>
using namespace std;

struct node
{ int floor;
int time;
};

#define MAX 100
int flag[MAX];
int regular[MAX];

int BFS()
{
queue<node>Q;//lz establish a queue
node p,q;
int n,i,start,end;

cin>>n>>start>>end;
p.floor=start;
flag[start]=1;

for(i=1;i<=n;i++)
cin>>regular[i];//record the moving regular of each floor

p.time=0;//initialize the time
Q.push(p);

while(!Q.empty())

{
p=Q.front;
Q.pop();
q=p;

if(p.floor==end)
return p.time;

q.floor+=regular[q.floor];
if(q.floor<=n&&flag[q.floor]==0)
{
q.time++;
flag[q.floor]=1;
Q.push(q);
}
q=p;

q.floor-=regular[q.floor];
if(q.floor>=1&&flag[q.floor]==0)
{
q.time++;
flag[q.floor]=1;
Q.push(q);
}
}

}

void main()
{
memset(flag,0,sizeof(flag));
cout<<BFS()<<endl;
}
...全文
21 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
W170532934 2012-07-16
  • 打赏
  • 举报
回复
楼主又是个只给代码,什么都不说的人。

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧