码迷,mamicode.com
首页 > 其他好文 > 详细

POJ 3278 Catch That Cow 【简单bfs】

时间:2018-03-31 10:13:30      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:front   blank   target   set   names   break   nbsp   strong   移动   

题目链接

 

题目大意:

 

 FJ要抓奶牛。

  开始输入N(FJ的位置)K(奶牛的位置)。

 

  FJ有三种移动方法:1、向前走一步,耗时一分钟。

 

                                 2、向后走一步,耗时一分钟。

 

                                 3、向前移动到当前位置的两倍N*2,耗时一分钟。

 

 问FJ抓到奶牛的最少时间。

PS:奶牛是不会动的。

 

#include <stdio.h>           
#include <string.h>
#include <queue>
#include <iostream>
#include <algorithm>
using namespace std;
int vis[100005];
int n, k;
struct dian
{
    int x;
    long long s;
};
queue<dian>q;

long long bfs()
{
    int i, j;
    dian now, next;
    while (!q.empty())
    {
        now = q.front();
        q.pop();
        if (now.x == k)break;
        if (now.x - 1 >= 0 && !vis[now.x - 1])
        {
            next.x = now.x - 1;
            vis[next.x] = 1;
            next.s = now.s + 1;
            q.push(next);
        }
        if (now.x + 1 <=100000 && !vis[now.x + 1])
        {
            next.x = now.x + 1;
            vis[next.x] = 1;
            next.s = now.s + 1;
            q.push(next);
        }
        if (now.x *2 <= 100000 && !vis[now.x * 2])
        {
            next.x = now.x * 2;
            vis[next.x] = 1;
            next.s = now.s + 1;
            q.push(next);
        }
    }
    return now.s;
}

int main()
{
    int i, j;
    dian now;
    while (scanf("%d%d", &n, &k) != EOF)
    {
        memset(vis, 0, sizeof(vis));
        while (!q.empty())q.pop();
        now.x = n;
        now.s = 0;
        vis[now.x] = 1;
        q.push(now);
        printf("%lld\n", bfs());
    }
    return 0;
}

 

2018-03-31

 

POJ 3278 Catch That Cow 【简单bfs】

标签:front   blank   target   set   names   break   nbsp   strong   移动   

原文地址:https://www.cnblogs.com/00isok/p/8681089.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!