【题目描述】
农夫知道一头牛的位置,想要抓住它。农夫和牛都位于数轴上,农夫起始位于点N(0≤N≤100000),牛位于点K(0≤K≤100000)。农夫有两种移动方式:
1、从X移动到X-1或X+1,每次移动花费一分钟
2、从X移动到2*X,每次移动花费一分钟
假设牛没有意识到农夫的行动,站在原地不动。农夫最少要花多少时间才能抓住牛?
【输入】
两个整数,N和K。
【输出】
一个整数,农夫抓到牛所要花费的最小分钟数。
【输入样例】
5 17
【输出样例】
4
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<string>
#include<cstdlib>
#include<queue>
#include<vector>
#define INF 0x3f3f3f3f
#define PI acos(-1.0)
#define N 100001
#define MOD 2520
#define E 1e-12
using namespace std;
bool vis[N];
int dir[2]={-1,1};
struct node
{
int x;
int step;
}q[N*10];
void bfs(int n,int k)
{
int head=1,tail=1;
memset(vis,0,sizeof(vis));
vis[n]=1;
q[tail].x=n;
q[tail].step=0;
tail++;
while(head<tail)
{
int x=q[head].x;
int step=q[head].step;
if(x==k)
{
printf("%d\n",step);
break;
}
int nx;
for(int i=0;i<2;i++)
{
nx=x+dir[i];
if(0<=nx&&nx<N&&vis[nx]==0)
{
vis[nx]=1;
q[tail].x=nx;
q[tail].step=step+1;
tail++;
}
}
nx=x*2;
if(nx>=0&&nx<N&&vis[nx]==0)
{
vis[nx]=1;
q[tail].x=nx;
q[tail].step=step+1;
tail++;
}
head++;
}
}
int main()
{
int n,k;
scanf("%d%d",&n,&k);
if(k<n)
{
printf("%d",n-k);
exit(0);
}
bfs(n,k);
return 0;
}
信息学奥赛一本通T1253:广度优先搜索(BFS) 抓住那头牛 归属于 广度优先搜索(BFS),更多同类题解源程序见:广度优先搜索(BFS) 和 抓住那头牛
0 篇文章
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!