题目详情:
A strange lift
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 47831 Accepted Submission(s): 16738
Here comes the problem: when you are on floor A,and you want to go to floor B,how many times at least he has to press the button "UP" or "DOWN"?
The first line contains three integers N ,A,B( 1 <= N,A,B <= 200) which describe above,The second line consist N integers k1,k2,....kn.
A single 0 indicate the end of the input.
题目大意:
解题思路:
AC代码:
#include<iostream>
#include<vector>
#include<queue>
using namespace std;
class Elevator{
public:
int floor;
int times;
};
void BFS(vector<int>& l_num,int l_begin,int l_end){
int min_times=0;
vector<bool> visit(l_num.size(),1);
queue<Elevator> l_q;//类队列
Elevator cur,nex;
cur.floor=l_begin;//初始化
cur.times=0;//初始化
l_q.push(cur);//入队
while(!l_q.empty()){
cur=l_q.front();//赋值
l_q.pop();//出队
visit[cur.floor]=0;//该楼层已经来过
if(cur.floor==l_end){//如果当前楼层和目标楼层一样,结束循环
cout<<cur.times<<endl;
return;
}
nex.floor=cur.floor+l_num[cur.floor];
nex.times=cur.times+1;//按的次数加一
if(nex.floor<=l_end){//没超过目标楼层
if(visit[nex.floor]){
visit[nex.floor]=0;//标记来过该楼层
l_q.push(nex);//入队
}
}
nex.floor=cur.floor-l_num[cur.floor];//往楼下去
nex.times=cur.times+1;//按的次数加一
if(nex.floor>0){//下一个要去的楼层大于0
if(visit[nex.floor]){
visit[nex.floor]=0;//标记来过该楼层
l_q.push(nex);//入队
}
}
}
cout<<"-1"<<endl;
}
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
int n,begin,end;
while(cin>>n>>begin>>end){
vector<int> num(n+1,0);
for(int i=1;i<=n;++i){
cin>>num[i];
}
BFS(num,begin,end);
}
return 0;
}
推荐几款学习编程的网站
免费在线开发平台(LTPP在线开发平台 | LTPP宇宙文档)
探索编程世界的新天地,为学生和开发者精心打造的编程平台,现已盛大开启!这个平台汇集了近4000道精心设计的编程题目,覆盖了C、C++、JavaScript、TypeScript、Go、Rust、PHP、Java、Ruby、Python3以及C#等众多编程语言,为您的编程学习之旅提供了一个全面而丰富的实践环境。
在这里,您不仅可以查看自己的代码记录,还能轻松地在云端保存和运行代码,让编程变得更加便捷。平台还提供了私聊和群聊功能,让您可以与同行们无障碍交流,分享文件,共同进步。不仅如此,您还可以通过阅读文章、参与问答板块和在线商店,进一步拓展您的知识边界。
为了提升您的编程技能,平台还设有每日一题、精选题单以及激动人心的编程竞赛,这些都是备考编程考试的绝佳资源。更令人兴奋的是,您还可以自定义系统UI,选择视频或图片作为背景,打造一个完全个性化的编码环境,让您的编程之旅既有趣又充满挑战。
免费公益服务器(LTPP公益LINUX服务器分享 | LTPP宇宙文档)
作为开发者或学生,您是否为搭建和维护编程环境而困扰?现在,有一款免费的公共服务器,内置多种编程语言的编程环境,并且配备了在线版VS Code。让您可以随时随地在线写代码,无需复杂配置,专注于开发和学习。(PS:毕竟是免费公共的服务器,任何人都能够使用,为了数据隐私和安全,请勿上传重要数据,仅用于学习)
免费公益MYSQL(LTPP公益MYSQL分享 | LTPP宇宙文档)
作为一名开发者或学生,您是否常常为数据库环境的搭建而烦恼?是否因为预算有限而无法使用高性能的数据库服务?现在,有一款免费的MySQL服务器,专为开发者和学生量身打造,让你轻松无忧地进行开发和学习!内置在线phpmyadmin管理面板,方便用户查看数据。(PS:毕竟是免费公共的MYSQL,任何人都能够使用,为了数据隐私和安全,请勿上传重要数据,仅用于学习)
免费在线WEB代码编辑器(LTPP在线WEB编辑器 | LTPP宇宙文档)
无论你是开发者还是学生,编程环境的搭建和管理可能会占用你宝贵的时间和精力。现在,有一款强大的免费在线代码编辑器,支持多种编程语言,让您可以随时随地编写、调试和运行代码,提升编程效率,专注于创意和开发。
免费二维码生成器(LTPP二维码生成器 | LTPP宇宙文档)
无论是企业宣传、活动推广,还是个人信息分享,二维码都是一种快速、高效的信息传递方式。现在,有一款功能强大的二维码生成器,不仅易于使用,还具备多种便捷功能,帮助您更轻松地生成和管理二维码。