hdu1548

需要注意的是对于每一层,上下是有方向的, 对于某一层只有上和下都走过了才能标记为不能在到达该层;

#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>

using namespace std;

const int M = 2005;
int vist[M][2];
int s[M];
struct node
{

    int id;
    int sum;
};
int n, s1, e;
int ans;

int solve(int s1, int e)
{
    memset(vist, 0, sizeof(vist));

    queue<node>que;
    node cur, next;
    cur.id = s1;
    cur.sum = 0;
    que.push(cur);
    while(!que.empty())
    {

        cur = que.front();
        que.pop();
        if(cur.id == e)
        {
            return cur.sum;
        }

        if(!vist[cur.id][1])
        {
            if(cur.id + s[cur.id] <= n)
            {

                next.id = cur.id + s[cur.id];
                next.sum = cur.sum + 1;
               if(next.id == e)
                return next.sum;
                que.push(next);
                vist[cur.id][1] = 1;
            }
        }
       if(!vist[cur.id][0])
        {
if(cur.id - s[cur.id] >= 1)
{ next.id = cur.id - s[cur.id]; next.sum = cur.sum + 1; if(next.id == e) return next.sum; que.push(next); vist[cur.id][0] = 1; } } } return -1; } int main() { int a; while(scanf("%d", &n) != EOF && n) { scanf("%d%d", &s1, &e); for(int i = 1; i <= n; i++) { scanf("%d", &a); s[i] = a; } ans = solve(s1, e); printf("%d\n", ans); } return 0; }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值