LeetCode 1654. 到家的最少跳跃次数(BFS)
文章目錄
- 1. 題目
- 2. 解題
1. 題目
有一只跳蚤的家在數(shù)軸上的位置 x 處。請(qǐng)你幫助它從位置 0 出發(fā),到達(dá)它的家。
跳蚤跳躍的規(guī)則如下:
- 它可以 往前 跳恰好 a 個(gè)位置(即往右跳)。
- 它可以 往后 跳恰好 b 個(gè)位置(即往左跳)。
- 它不能 連續(xù) 往后跳 2 次。
- 它不能跳到任何 forbidden 數(shù)組中的位置。
跳蚤可以往前跳 超過(guò) 它的家的位置,但是它 不能跳到負(fù)整數(shù) 的位置。
給你一個(gè)整數(shù)數(shù)組 forbidden ,其中 forbidden[i] 是跳蚤不能跳到的位置,同時(shí)給你整數(shù) a, b 和 x ,請(qǐng)你返回跳蚤到家的最少跳躍次數(shù)。
如果沒(méi)有恰好到達(dá) x 的可行方案,請(qǐng)你返回 -1 。
來(lái)源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/minimum-jumps-to-reach-home
著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系官方授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。
2. 解題
- 廣度優(yōu)先搜索,搜索的位置需要比 x 大一些
- 然后往回跳的時(shí)候,注意不用標(biāo)記已經(jīng)訪問(wèn)過(guò),往前跳的時(shí)候標(biāo)記訪問(wèn)即可
56 ms 14.7 MB
或者一個(gè)位置,使用兩個(gè)訪問(wèn)標(biāo)記,前向的和后向的
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/
長(zhǎng)按或掃碼關(guān)注我的公眾號(hào)(Michael阿明),一起加油、一起學(xué)習(xí)進(jìn)步!
總結(jié)
以上是生活随笔為你收集整理的LeetCode 1654. 到家的最少跳跃次数(BFS)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Pytorch 神经网络nn模块
- 下一篇: LeetCode 982. 按位与为零的