社区讨论

18分球跳玄关感谢(bfs)

P1135奇怪的电梯参与者 3已保存回复 4

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
4 条
当前快照
1 份
快照标识符
@mhz47e0m
此快照首次捕获于
2025/11/15 01:11
4 个月前
此快照最后确认于
2025/11/16 13:44
4 个月前
查看原帖
using namespace std;
int n,a,b,k[209];
bool v[209];
int main(){
    cin>>n>>a>>b;
    for (int i=1;i<=n;i++)cin>>k[i];
    queue<pair<int,int> >q;
    q.push(make_pair(a,0));
    while(!q.empty()){
        pair<int,int>t=q.front();
        q.pop();
        if (t.first==n){
            cout<<t.second;
            return 0;
        }
        if (!v[t.first-k[t.first]]&&t.first-k[t.first]>0){
            v[t.first-k[t.first]]=1;
            q.push(make_pair(t.first-k[t.first],t.second+1));
            v[t.first-k[t.first]]=0;
        }
        if (!v[t.first+k[t.first]]&&t.first+k[t.first]<=n){
            v[t.first-k[t.first]]=1;
            q.push(make_pair(t.first+k[t.first],t.second+1));
            v[t.first-k[t.first]]=0;
        }
    }
}

回复

4 条回复,欢迎继续交流。

正在加载回复...