抓住那只牛

Description

农夫约翰被通知,他的一只奶牛逃逸了!所以他决定,马上出发,尽快把那只奶牛抓回来,他们都站在数轴上.

约翰在N(0≤N≤100000)处,奶牛在K(0≤K≤100000)处.

约翰有两种办法移动,步行和瞬移:步行每秒种可以让约翰从x处走到x+1或x-1处;而瞬移则可让他在1秒内从x处消失,在2x处出现.

然而那只逃逸的奶牛,悲剧地没有发现自己的处境多么糟糕,正站在那儿一动不动.

那么,约翰需要多少时间抓住那只牛呢?

Format

Input

仅有两个整数N和K.

Output

最短的时间.

Samples

输入数据 1

5 17

Copy

输出数据 1

4

这道题只需要把3种情况算出来,取最小值;

CODE

#include<bits/stdc++.h>
using namespace std;
int a[10000007],s[1000007],d[7];
int main() {
	int n,k;
	cin>>n>>k;
	if(k==n)
	{
		cout<<0;
		return 0;
	}
	a[1]=n;
	s[n]=1;
	int head=1,tail=1;
	while(head<=tail)
	{
		int ans=a[head];
		d[1]=ans+1;
		d[2]=ans-1;
		d[3]=ans*2;
		for(int i=1;i<=3;i++)
		{
			if(d[i]>=0&&d[i]<=100000&&s[d[i]]==0)
			{
				tail++;
				a[tail]=d[i];
				s[d[i]]=s[ans]+1;
				if(a[tail]==k)
				{
					cout<<s[k]-1;
					return 0;
				}
			}
		}
		head++;
	}
	return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值