[C++]洛谷B3626 跳跃机器人(题干 + 详细讲解, BFS练习题)

题目解析

题干

题目描述

地上有一排格子,共n个位置。机器猫站在第一个格子上,需要取第n个格子里的东西。

机器猫当然不愿意自己跑过去,所以机器猫从口袋里掏出了一个机器人!这个机器人的行动遵循下面的规则:

初始时,机器人位于1号格子, 若机器人目前在x格子,那么它可以跳跃到x + 1, x - 1, 2 * x里的一个格子(不允许跳出界

问机器人最少需要多少次跳跃,才能到达n号格子。


输入格式

第1行, 一个正整数n


输出格式

一行, 一个正整数, 表示最小跳跃次数.


输入输出样例

样例1

input输入:

复制代码
30

expected output期望输出:

复制代码
6

样例2

input输入:

复制代码
50

expected output期望输出:

复制代码
7

样例3

input输入:

复制代码
64

expected output期望输出:

复制代码
6

样例4

input输入:

复制代码
63

expected output期望输出:

复制代码
8

数据范围

对于100%的数据,有 1≤n≤1000000。




知识点提示

需要运用以下知识点:

  • C++基础语法
  • 简单的bfs广度优先搜索思想及代码实现能力
  • 对于queue队列或vector向量等的了解与灵活运用

拥有以上知识点的掌握之后, 你可以尝试做出这道题.


AC代码与解析

解析请看注释

cpp 复制代码
#include <iostream>
#include <queue>
#include <algorithm>
using namespace std;

// 定义全局变量
int n;                // 存储目标数字
bool vis[1000005];    // 访问标记数组,记录数字是否已被访问过
int dis[1000005];     // 距离数组,记录从1到当前数字的最短步数

// 广度优先搜索函数,计算从1到n的最短步数
int bfs(){
    queue<int> q;     // 创建队列用于BFS
    q.push(1);        // 初始状态:数字1入队
    vis[1] = true;    // 标记数字1已访问
    dis[1] = 0;       // 数字1到自身的距离为0
    
    while(!q.empty()){  // 当队列不为空时循环
        int x = q.front();  // 取出队首元素
        if(x == n) return dis[x];  // 如果找到目标数字,返回当前步数
        q.pop();            // 弹出队首元素
        
        // 尝试三种操作:减1、加1、乘2
        
        // 操作1:数字减1
        int y = x - 1;
        if(0 <= y && y <= n && !vis[y]){  // 检查数字是否有效且未被访问
            vis[y] = true;          // 标记已访问
            dis[y] = dis[x] + 1;    // 更新步数
            q.push(y);              // 入队
        }
        
        // 操作2:数字加1
        y = x + 1;
        if(0 <= y && y <= n && !vis[y]){  // 检查数字是否有效且未被访问
            vis[y] = true;          // 标记已访问
            dis[y] = dis[x] + 1;    // 更新步数
            q.push(y);              // 入队
        }
        
        // 操作3:数字乘2
        y = x * 2;
        if(0 <= y && y <= n && !vis[y]){  // 检查数字是否有效且未被访问
            vis[y] = true;          // 标记已访问
            dis[y] = dis[x] + 1;    // 更新步数
            q.push(y);              // 入队
        }
    }
    return -1;  // 如果无法到达目标数字,返回-1
}

int main(){
    cin >> n;            // 输入目标数字
    cout << bfs() << endl;  // 调用广度优先搜索并输出结果
    return 0;
}
相关推荐
生信碱移11 小时前
单细胞空转CNV分析工具:比 inferCNV 快10倍?!兼容单细胞与空转的 CNV 分析与聚类,竟然还支持肿瘤的亚克隆树构建!
算法·机器学习·数据挖掘·数据分析·聚类
CYTElena11 小时前
JAVA关于集合的笔记
java·开发语言·笔记
我是唐青枫11 小时前
深入理解 C#.NET Parallel:并行编程的正确打开方式
开发语言·c#·.net
RFCEO12 小时前
用手机写 Python程序解决方案
开发语言·python·智能手机·qpython环境安装
DICOM医学影像12 小时前
15. Go-Ethereum测试Solidity ERC20合约 - Go-Ethereum调用合约方法
开发语言·后端·golang·区块链·智能合约·以太坊·web3.0
Brduino脑机接口技术答疑12 小时前
TDCA 算法在 SSVEP 场景中:Padding 的应用对象与工程实践指南
人工智能·python·算法·数据分析·脑机接口·eeg
quant_198612 小时前
如何处理大规模行情数据:从源头到终端的实战教程
大数据·开发语言·经验分享·python·金融
哆啦code梦12 小时前
Rust:高性能安全的现代编程语言
开发语言·rust
玄同76512 小时前
Python 装饰器:LLM API 的安全与可观测性增强
开发语言·人工智能·python·安全·自然语言处理·numpy·装饰器
superman超哥12 小时前
Rust 过程宏开发入门:编译期元编程的深度实践
开发语言·后端·rust·元编程·rust过程宏·编译期