【BFS】POJ 3278 Catch That Cow

这段时间要沉迷刷题一段时间了,就让CSDN陪我一起吧!

一、题目大意

题目的大致意思就是John要去抓奶牛,一开始John在数轴上的位置N,奶牛在数轴上的位置K,然后问John最快可以经过几步把奶牛抓住?

给出Johnson的行走策略:

  1. 要么可以从X位置走到X+1或X-1
  2. 要么可以从X位置瞬移到2*X的位置

二、题目思路以及AC代码

这题很明显也是一道BFS的变种,只需根据其给定的行走策略,变化BFS的行走策略即可。

下面给出AC代码:

#include <iostream>
#include <queue>
#define MAXN 100010
using namespace std;

struct Point {
	int x;
	int step;
};

int N, K;
Point start;

int dx[2] = { -1, 1 };
bool vis[MAXN];

int bfs() {
	for (int i = 0; i < MAXN; i++) {
		vis[i] = false;
	}

	queue<Point> q;
	q.push(start);
	vis[start.x] = true;

	while (!q.empty()) {
		Point cur = q.front(); q.pop();

		for (int i = 0; i < 2; i++) {
			int nx = cur.x + dx[i];

			if (nx < 0 || nx > 100000) continue;
			if (vis[nx]) continue;

			if (nx == K)
				return cur.step + 1;

			vis[nx] = true;
			Point next;
			next.x = nx;
			next.step = cur.step + 1;
			q.push(next);
		}

		int nx = 2 * cur.x;
		if (nx >= 0 && nx <= 100000 && !vis[nx]) {

			if (nx == K)
				return cur.step + 1;

			vis[nx] = true;
			Point next;
			next.x = nx;
			next.step = cur.step + 1;
			q.push(next);
		}
	}

	return -1;
}

int main()
{
	cin >> N >> K;

	if (N == K) {
		cout << 0 << endl;
	}
	else {
		start.x = N;
		start.step = 0;

		cout << bfs() << endl;
	}

    return 0;
}

如果有问题,欢迎大家指正!!!

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值