当前位置: 首页 > news >正文

一维坐标的移动(bfs)

在一个长度为n的坐标轴上,小S想从A点移动B点。

他的移动规则如下:

向前一步,坐标增加1。

向后一步,坐标减少1。

跳跃一步,使得坐标乘2。

小S不能移动到坐标小于0或大于n的位置。

小S想知道从A点移动到B点的最少步数是多少,你能帮他计算出来么?

输入格式

第一行输入三个整数n,A,B,分别代表坐标轴长度,起始点坐标,终点坐标。(0<=A,B<=n<=50000)

输出格式

输出一个整数占一行,代表小S要走的最少步数。

样例输入

10 2 7

样例输出

3

dfs深度优先(时间复杂度会比较高,这里仅供理解题目)

#include<iostream>
using namespace std;
const int N=50005;
bool st[N];
int n,A,B;
int ans;
void dfs(int x,int step){if(x==B){//结束条件 ans=step;return;}int y;//向前走,坐标+1y=x+1;if(!st[y]&&y>=1&&y<=n){st[y]=true;dfs(y,step+1);st[y]=false;}//向后走,坐标-1y=x-1;if(!st[y]&&y>=1&&y<=n){st[y]=true;dfs(y,step+1);st[y]=false;}//跳跃,坐标*2 y=x*2;if(!st[y]&&y>=1&&y<=n){st[y]=true;dfs(y,step+1);st[y]=false;}
}
int main(){cin>>n>>A>>B;dfs(A,0);cout<<ans<<endl;return 0;
}

bfs广度优先

 

#include<iostream>
#include<queue>
using namespace std;
const int N=50005;
bool st[N];
typedef struct point{int x;int step;
}point;
queue<point> q;
int n,A,B;void bfs(){while(q.size()){point p=q.front();if(p.x==B){break;}point next;int a;//向前走,坐标+1 a=p.x+1;if(!st[a]&&a>=1&&a<=n){next.x=a;next.step=p.step+1;q.push(next);//入队st[a]=true; }//向后走,坐标-1 a=p.x-1;if(!st[a]&&a>=1&&a<=n){next.x=a;next.step=p.step+1;q.push(next);//入队st[a]=true; }//跳跃,坐标*2 a=p.x*2;if(!st[a]&&a>=1&&a<=n){next.x=a;next.step=p.step+1;q.push(next);//入队st[a]=true; }q.pop(); }
}
int main(){cin>>n>>A>>B;point start;start.x=A;start.step=0;q.push(start);bfs();cout<<q.front().step<<endl;return 0;
} 

 

http://www.lryc.cn/news/320541.html

相关文章:

  • 面试题 整理
  • 苍穹外卖-day08:导入地址簿功能代码(单表crud)、用户下单(业务逻辑)、订单支付(业务逻辑,cpolar软件)
  • Java面试相关问题
  • Linux Shell中的循环控制语句
  • proto3语言指南
  • 解决后端传给前端的日期问题
  • MySQL中的索引失效情况介绍
  • SpringBoot异常:类文件具有错误的版本 61.0, 应为 52.0的解决办法
  • Cloudways搭建WordPress外贸独立站完整教程
  • 关于 闰年 的小知识,为什么这样判断闰年
  • Elasticsearch:调整近似 kNN 搜索
  • UE5数字孪生系列笔记(二)
  • 基于vue实现bilibili网页
  • 计算机二级(Python)真题讲解每日一题:《十字叉》
  • 基于正点原子潘多拉STM32L496开发板的简易示波器
  • 【Docker】apisix 容器化部署
  • 基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的障碍物检测系统(深度学习代码+UI界面+训练数据集)
  • 从零开始学HCIA之SDN04
  • GET 和 POST 有什么区别?
  • Qt学习--继承(并以分文件实现)
  • 软考75-上午题-【面向对象技术3-设计模式】-设计模式的要素
  • Matlab|面向低碳经济运行目标的多微网能量互联优化调度
  • 3.Gen<I>Cam文件配置
  • 【兆易创新GD32H759I-EVAL开发板】 TLI(TFT LCD Interface)用法详细介绍
  • 恒创科技:什么是BGP线路服务器?BGP机房的优点是什么?
  • 苍穹外卖-day04:项目实战-套餐管理(新增套餐,分页查询套餐,删除套餐,修改套餐,起售停售套餐)业务类似于菜品模块
  • 深入探索C与C++的混合编程
  • 数组中的flat方法如何实现
  • 计算机考研|北航北理北邮怎么选?
  • 面试算法-52-对称二叉树