亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Leetcode 403 - Frog Jump(dp or bfs)

2019-11-14 10:08:51
字體:
來源:轉載
供稿:網友

題意

給定一個石頭的序列,青蛙從0開始跳,第一次只能跳一步,不能落入水中。

現在,假如我從上一個石頭跳到這個石頭是k步,那么,我們下一次只能跳k - 1或k或k + 1步,問:青蛙最后能否調到最后一個石頭上。

思路

算法1

爆搜,本來以為會T,但是實際上中間會有很多情況會落入水中,所以bfs能過。

算法2

dp,我們可以這樣考慮:我們當前在位置i,是從位置j經過k步到達位置i的。那么我們下一次能夠達到stonesi+kstonesi+k?1stonesi+k+1。

于是,我們的狀態表示為:d[i],從i之前的某一位置j經過k步跳過來的,那么,很明顯我們的d[i]有很多種情況,我們可以再加一維j表示從j經過d[i,j]步跳過來的,也可以用一個set來存我們經過多少步到i的。

即,我們定義我們的d[i]unordered_map<int, set<int>> pos,key為stones[i],value為跳到這個位置的所有可能步數集合。

那么,我們接下來需要做的就是:假設我們當前在位置i,我們取出pos[stones[i]]對應的集合tk。對于tk內的每一個步數k,那么我們下一次就可以走到的位置newpos為stones[i] + k或stones[i] + k - 1或stones[i] + k + 1。然后判斷newpos是否為一個石頭,如果是,那么我們就將可行的解加入pos即可。

最后,只需要判斷pos[stones[n - 1]].size()>0即可(即是否存在到終點的可行步數)

代碼

//algorithm 1#define PII pair<int, int>#define mp make_pairclass Solution {public: bool canCross(vector<int>& stones) { set<PII> vis; set<int> has; for (auto x : stones) has.insert(x); int ll = stones[stones.size() - 1]; queue<PII> q; q.push(mp(1, 1)); while (!q.empty()) { PII t = q.front(); q.pop(); if (t.first == ll) return true; if (vis.find(t) != vis.end()) continue; else vis.insert(t); int x = t.first, k = t.second; if (has.find(x) != has.end()) { if (x + k <= ll && has.find(x + k) != has.end()) q.push(mp(x + k, k)); if (x + k - 1 <= ll && has.find(x + k - 1) != has.end()) q.push(mp(x + k - 1, k - 1)); if (x + k + 1 <= ll && has.find(x + k + 1) != has.end()) q.push(mp(x + k + 1, k + 1)); } } return false; }};//algorithm 2class Solution {public: bool canCross(vector<int>& stones) { unordered_map<int, set<int>> pos; set<int> tmp; for (auto x : stones) pos[x] = tmp; for (int i = 0; i < stones.size(); i++) { set<int> sk = pos[stones[i]]; for (auto k : sk) { for (int step = k - 1; step <= k + 1; step++) { if (step > 0 && pos[stones[i] + step] != NULL) pos[stones[i] + step].insert(stones[i] + step); } } } return pos[stones.size() - 1].size() > 0; }};
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性xxxx在线播放| 欧美大片va欧美在线播放| 欧美精品激情在线| 国产精品最新在线观看| 欧美巨乳美女视频| 中文字幕无线精品亚洲乱码一区| 久久精品91久久香蕉加勒比| 国产精品欧美日韩一区二区| 色在人av网站天堂精品| 欧美日韩国产91| 精品网站999www| 97国产精品视频人人做人人爱| 国产精品久久久久久久美男| 久久视频在线播放| 久久国产精品久久久久久| 国产精品成人免费视频| 久久精视频免费在线久久完整在线看| 久久影院模特热| 色综合天天狠天天透天天伊人| 久久久91精品国产一区不卡| 国产日韩欧美夫妻视频在线观看| 欧美另类69精品久久久久9999| 国产乱人伦真实精品视频| 国产精品视频一区二区高潮| 九九精品在线播放| 亚洲精品久久久久久久久| 成人欧美一区二区三区在线湿哒哒| 国产精品久久久久aaaa九色| 午夜伦理精品一区| 日韩国产中文字幕| 日韩精品在线观看一区| 欧美在线观看www| 欧美大人香蕉在线| 98视频在线噜噜噜国产| 国产精品99久久久久久久久久久久| 中文在线不卡视频| 日韩av在线直播| 国产精品视频1区| 91精品国产色综合久久不卡98口| 自拍偷拍亚洲一区| 亚洲黄色av女优在线观看| 欧美日韩国产999| 欧美性猛交xxxx免费看久久久| 国产精品99蜜臀久久不卡二区| 欧美日韩加勒比精品一区| 色播久久人人爽人人爽人人片视av| 亚洲欧美三级在线| 国产成人精品国内自产拍免费看| 国产精品久久久久99| 欧美一二三视频| 亚洲精品国产欧美| 性日韩欧美在线视频| 亚洲精品国产拍免费91在线| 亚洲免费视频网站| 成人性生交大片免费看视频直播| 欧美专区在线视频| 91精品久久久久久久久中文字幕| 欧美专区在线观看| 亚洲sss综合天堂久久| 日韩av免费在线播放| 欧美一区二区大胆人体摄影专业网站| 国产一区二区在线免费视频| 国产欧美精品一区二区三区介绍| 午夜免费久久久久| 国自产精品手机在线观看视频| 欧美香蕉大胸在线视频观看| 亚洲欧洲在线看| 国产精品18久久久久久麻辣| 92国产精品久久久久首页| 久久国产精品首页| 日韩成人中文字幕在线观看| 亚洲国产精久久久久久| 日韩欧美高清在线视频| 精品久久久久久久久中文字幕| 国产精品视频一| 欧美在线精品免播放器视频| 最近日韩中文字幕中文| 一区二区中文字幕| 亚洲永久免费观看| 亚洲免费电影一区| 成人在线小视频| 国产成人精品国内自产拍免费看| 国产精品久久久久久久一区探花| 中文字幕亚洲专区| 精品视频在线播放色网色视频| 日本精品一区二区三区在线播放视频| 国产精品久久在线观看| 国产成人精品网站| 色偷偷偷亚洲综合网另类| 亚洲福利视频在线| 亚洲国产日韩欧美在线动漫| 日韩专区在线播放| 日本道色综合久久影院| 欧美日韩成人在线播放| 亚洲欧美国产精品久久久久久久| 日韩美女中文字幕| 国产精品综合久久久| 国产成人精品久久二区二区91| 欧美激情高清视频| 91网站免费观看| 国产精品爱久久久久久久| 久久精品国产成人精品| 成人夜晚看av| 亚洲色图18p| 国产精品一久久香蕉国产线看观看| 国产精品444| 久久久久久高潮国产精品视| 18一19gay欧美视频网站| 日本在线观看天堂男亚洲| 国产成人在线一区| 久久久久一本一区二区青青蜜月| 亚洲天堂男人天堂| 精品五月天久久| 国产精品一区二区3区| 国产精品十八以下禁看| 91免费视频国产| 亚洲国产精品一区二区三区| 国产精品精品视频一区二区三区| 欧美性猛交xxx| 午夜精品理论片| 亚洲成人精品在线| 日本成人激情视频| 亚洲欧美日韩一区在线| 国产视频亚洲精品| 欧美精品在线免费| 日韩av网站大全| 俺去啦;欧美日韩| 亚洲加勒比久久88色综合| 精品福利一区二区| 亚洲精品美女在线观看| 国产精品久久二区| 日韩亚洲第一页| 亚洲精品福利在线| 成人久久久久久久| 欧美精品videosex牲欧美| 中文字幕日韩欧美| 精品久久久久久久久久久| 91国内精品久久| 亚洲人成电影在线观看天堂色| 正在播放亚洲1区| 亚洲人成电影在线播放| 国产美女被下药99| 欧美贵妇videos办公室| 欧美激情按摩在线| 色www亚洲国产张柏芝| 日韩在线视频播放| 国内精品伊人久久| 91久久国产婷婷一区二区| 在线播放国产一区中文字幕剧情欧美| 91精品国产综合久久香蕉的用户体验| 亚洲香蕉av在线一区二区三区| 国产亚洲精品久久久久动| 久久国产加勒比精品无码| 国产精品老女人精品视频| 福利视频导航一区| 欧美激情第1页| 亚洲女在线观看| 色偷偷av一区二区三区| 国产午夜精品久久久| 日韩av免费看网站| 亚洲丝袜一区在线| 人九九综合九九宗合| 97超视频免费观看| www.亚洲天堂|