日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

LeetCode 1654. 到家的最少跳跃次数(BFS)

發(fā)布時(shí)間:2024/7/5 编程问答 53 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LeetCode 1654. 到家的最少跳跃次数(BFS) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

文章目錄

    • 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 。

示例 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 中。

來(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)即可
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

或者一個(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)步!

創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

總結(jié)

以上是生活随笔為你收集整理的LeetCode 1654. 到家的最少跳跃次数(BFS)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。