Catch Taht Cow——一维广搜

题目

在这里插入图片描述

分析

以前学的广度遍历都是基于二维的,这个是一维的,还觉得满新奇的!
代码和二维的差不多,就是需要注意下这里移动位置的操作容易超出数组的范围,因此采用了分类讨论,而不是常见的for循环

代码

#include<iostream>
#include<queue>
#define N 1000010
using namespace std;
int n,m;
int visit[N];
struct node{
	int x,t;
};
node a,b;
void bfs(){
	queue<node> Q;
	a.x=n;b.x=m;
	a.t=0;b.t=0;
	visit[n]=1;
	Q.push(a);
	while(!Q.empty()) {
		a=Q.front();
		Q.pop();
		if(a.x==m)
		break;//因为这里的操作容易让数组下标超出数组范围,因此采用分类讨论 
		if(a.x-1>=0 and visit[a.x-1]==0){
			b.x=a.x-1;
			b.t=a.t+1;
			visit[b.x]=1;
			Q.push(b);
		}
		if(a.x+1<=100000 and visit[a.x+1]==0){
			b.x=a.x+1;
			b.t=a.t+1;
			visit[b.x]=1;
			Q.push(b);
		}
		if(a.x*2<=100000 and visit[a.x*2]==0){
			b.x=a.x*2;
			b.t=a.t+1;
			visit[b.x]=1;
			Q.push(b);
		}		
	}
	cout<<a.t<<endl;
}
int main(){
	cin>>n>>m;
	if(m<=n){
		cout<<n-m<<endl;
		return 0;
	}
	bfs();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MORE_77

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值