LeetCode140 單詞拆分II

2021-09-01 05:56:54 字數 520 閱讀 2909

leetcode140.單詞拆分ii

動態規劃+dfs+回溯。

動態規劃:根據139單詞拆分使用動態規劃dp[j][i]表示從s[j...i-1]是可拆分的,可以理解為長度len的字串有len+1可以分割的位置。

dfs:遞迴的遍歷當前字串,vectorpath用來記錄能夠拆分的一條路徑。

回溯:同一分支的多種情況,path.push_back(); dfs(); path.pop_back()。

class solution 

}} getpath(s, dp, len, len);

return res;

} void getpath(string& s, vector>& dp, int len, int cur)

tmp.erase(tmp.end() - 1);

res.push_back(tmp);

} for (int i = 0; i <= len; ++i)

} }};

leetcode 140單詞拆分

原想法 通過遍歷找出每個位點可能出現的單詞的列表,然後通過dfs遍歷找出所有的組合,有點類似於之前刷pat時用的dijstra dfs,如下 class solution else if cursor length 先通過迴圈搜尋出所有開始點可能出現的單詞 for int i 0 i全是a的那個點執...

LeetCode 140 單詞拆分 II

問題描述 給定乙個非空字串 s 和乙個包含非空單詞列表的字典 worddict,在字串中增加空格來構建乙個句子,使得句子中所有的單詞都在詞典中。返回所有這些可能的句子。說明 示例 1 輸入 s catsanddog worddict cat cats and sand dog 輸出 cats and...

leetcode140 單詞拆分 II

給定乙個非空字串 s 和乙個包含非空單詞列表的字典 worddict,在字串中增加空格來構建乙個句子,使得句子中所有的單詞都在詞典中。返回所有這些可能的句子。先判斷能否拆分,再dfs得出結果 class solution def wordbreak self,s str,worddict list ...