文章目录

  • 1. 题目
  • 2. 解题

1. 题目

有一只跳蚤的家在数轴上的位置 x 处。请你帮助它从位置 0 出发,到达它的家。

跳蚤跳跃的规则如下:

  • 它可以 往前 跳恰好 a 个位置(即往右跳)。
  • 它可以 往后 跳恰好 b 个位置(即往左跳)。
  • 不能 连续跳 2 次。
  • 它不能跳到任何 forbidden 数组中的位置。

跳蚤可以往前跳 超过 它的家的位置,但是它 不能跳到负整数 的位置。

给你一个整数数组 forbidden ,其中 forbidden[i] 是跳蚤不能跳到的位置,同时给你整数 a, b 和 x ,请你返回跳蚤到家的最少跳跃次数。
如果没有恰好到达 x 的可行方案,请你返回 -1 。

示例 1:
输入:forbidden = [14,4,18,1,15], a = 3, b = 15, x = 9
输出:3
解释:往前跳 3 次(0 -> 3 -> 6 -> 9),跳蚤就到家了。示例 2:
输入:forbidden = [8,3,16,6,12,20], a = 15, b = 13, x = 11
输出:-1示例 3:
输入:forbidden = [1,6,2,14,5,17,4], a = 16, b = 9, x = 7
输出:2
解释:往前跳一次(0 -> 16),然后往回跳一次(16 -> 7),跳蚤就到家了。提示:
1 <= forbidden.length <= 1000
1 <= a, b, forbidden[i] <= 2000
0 <= x <= 2000
forbidden 中所有位置互不相同。
位置 x 不在 forbidden 中。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/minimum-jumps-to-reach-home
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 广度优先搜索,搜索的位置需要比 x 大一些
  • 然后往回跳的时候,注意不用标记已经访问过,往前跳的时候标记访问即可
class Solution {public:int minimumJumps(vector<int>& forbidden, int a, int b, int x) {int endpos = x+4000;vector<bool> vis(endpos, false);unordered_set<int> fib(forbidden.begin(), forbidden.end());vis[0] = true;queue<pair<int,bool>> q;q.push({0,false});//位置,上一次是向后的吗int step = 0, size;while(!q.empty()) {size = q.size();while(size--){int p = q.front().first;bool back = q.front().second;if(p == x)return step;q.pop();if(p+a < endpos && !fib.count(p+a) && !vis[p+a]){vis[p+a] = true;q.push({p+a, false});}if(p-b > 0 && !fib.count(p-b) && !vis[p-b] && !back){// vis[p-b] = true; //不能写q.push({p-b, true});}}step++;}return -1;}
};

56 ms 14.7 MB

或者一个位置,使用两个访问标记,前向的和后向的

class Solution {public:int minimumJumps(vector<int>& forbidden, int a, int b, int x) {int endpos = x+4000;vector<vector<bool>> vis(endpos, vector<bool>(2,false));unordered_set<int> fib(forbidden.begin(), forbidden.end());vis[0][0] = vis[0][1] = true;queue<pair<int,bool>> q;q.push({0,false});//位置,上一次是向后的吗int step = 0, size;while(!q.empty()) {size = q.size();while(size--){int p = q.front().first;bool back = q.front().second;if(p == x)return step;q.pop();if(p+a < endpos && !fib.count(p+a) && !vis[p+a][0]){vis[p+a][0] = true;q.push({p+a, false});}if(p-b > 0 && !fib.count(p-b) && !vis[p-b][1] && !back){vis[p-b][1] = true; q.push({p-b, true});}}step++;}return -1;}
};

404 ms 49.2 MB


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!

LeetCode 1654. 到家的最少跳跃次数(BFS)相关推荐

  1. 跳跃游戏2(求最少跳跃次数)Python解法

    给你一个非负整数数组 nums ,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 你的目标是使用最少的跳跃次数到达数组的最后一个位置. 假设你总是可以到达数组的最后一 ...

  2. 跳子游戏--最少跳跃次数

    给你一个非负整数数组 nums ,你最初位于数组的第一个位置.数组中的每个元素代表你在该位置可以跳跃的最大长度.你的目标是使用最少的跳跃次数到达数组的最后一个位置. 假设你总是可以到达数组的最后一个位 ...

  3. 贪心:jump 游戏(获取最少跳跃的次数以及跳跃路径)

    一个数组存储了非负整型数据,数组中的第i个元素a[i],代表了可以从数组第i个 位置最多向前跳跃a[i]步;已知数组各元素的情况下,求是否可以从数组的第0个位置跳跃到数组的最后一个元素的位置,返回最少 ...

  4. LeetCode 871. Minimum Number of Refueling Stops 最少加油次数

    LeetCode 871. Minimum Number of Refueling Stops 本题是LeetCode 871题,最少加油次数. 题目描述 A car travels from a s ...

  5. LeetCode 1284. 转化为全零矩阵的最少反转次数(BFS 矩阵状态编码解码)

    1. 题目 给你一个 m x n 的二进制矩阵 mat. 每一步,你可以选择一个单元格并将它反转(反转表示 0 变 1 ,1 变 0 ).如果存在和它相邻的单元格,那么这些相邻的单元格也会被反转.(注 ...

  6. LeetCode 1210. 穿过迷宫的最少移动次数(状态压缩BFS)

    文章目录 1. 题目 2. 解题 1. 题目 你还记得那条风靡全球的贪吃蛇吗? 我们在一个 n*n 的网格上构建了新的迷宫地图,蛇的长度为 2,也就是说它会占去两个单元格. 蛇会从左上角((0, 0) ...

  7. LeetCode 1319. 连通网络的操作次数(BFS/DFS/并查集)

    文章目录 1. 题目 2. 解题 2.1 BFS 2.2 DFS 2.3 并查集 1. 题目 用以太网线缆将 n 台计算机连接成一个网络,计算机的编号从 0 到 n-1. 线缆用 connection ...

  8. LeetCode简单题之使每位学生都有座位的最少移动次数

    题目 一个房间里有 n 个座位和 n 名学生,房间用一个数轴表示.给你一个长度为 n 的数组 seats ,其中 seats[i] 是第 i 个座位的位置.同时给你一个长度为 n 的数组 studen ...

  9. LeetCode 2139. 得到目标值的最少行动次数(贪心)

    文章目录 1. 题目 2. 解题 1. 题目 你正在玩一个整数游戏.从整数 1 开始,期望得到整数 target . 在一次行动中,你可以做下述两种操作之一: 递增,将当前整数的值加 1(即, x = ...

最新文章

  1. kdevelop安装完成后如何启动
  2. 剑指offer:翻转单词顺序列
  3. 找到一个全能的免费空间!支持SQL和.net2.0
  4. 编译执行和解释执行/初识量子计算机
  5. BBR如何让Spotify流媒体更流畅?
  6. 【常用 JS 插件】jQuery TreeTable 树表格插件
  7. 如何使用MATLAB绘制平滑曲线
  8. 学习微信小程序的资料汇总---转载自知乎
  9. 程序员快收藏:国内一二线城市的互联网公司汇总
  10. AutoJs学习-2048全自动
  11. 安全集成服务资质是什么都有哪些等级?申请安全集成服务资质认证有什么好处?
  12. cubeIDE开发, UART的CubeMX及HAL库实现原理及底层分析
  13. python 获取年份_如何从Pythondate时间对象中提取年份?
  14. 工作中对数据分析思路的一点思考
  15. 二维数组作为函数的参数传递
  16. office转成PDF插件
  17. Oracle根据数据块ITL查找UNDO前镜像
  18. 步进电机 - 转速与转矩特性(三)
  19. vr报价单_七里河区vr全景展示报价表
  20. 七、鼎捷T100生产管理之PBI管理篇

热门文章

  1. 整理一些完全免费开放的API接口
  2. GitHub+Hexo搭建自己的Blog之-本地环境部署01
  3. python会不会出4_无极4网人生苦短,Python会不会被取代?国外网友
  4. ZedGraph使用经验
  5. docker二进制安装mysql_Docker搭建MySQL读写分离主从模式 分布式数据库中间件Mycat分库分表应用...
  6. 解决模拟MOSS用户调用WebService打开个人站点进行操作
  7. 文本分类的一种对抗训练方法
  8. JZOJ 5776. 【NOIP2008模拟】小x游世界树
  9. LINQ简记(1):基本语法
  10. HDU-4089 Activation (概率DP求概率)