摘要:題目要求現(xiàn)在有一個非空字符串和一個非空的字典?,F(xiàn)在向中添加空格從而構(gòu)成一個句子,其中這個句子的所有單詞都存在與中。
題目要求
Given a non-empty string s and a dictionary wordDict containing a list of non-empty words, add spaces in s to construct a sentence where each word is a valid dictionary word. You may assume the dictionary does not contain duplicate words. Return all such possible sentences. For example, given s = "catsanddog", dict = ["cat", "cats", "and", "sand", "dog"]. A solution is ["cats and dog", "cat sand dog"].
現(xiàn)在有一個非空字符串s和一個非空的字典wordDict?,F(xiàn)在向s中添加空格從而構(gòu)成一個句子,其中這個句子的所有單詞都存在與wordDic中。字典中不包含重復的單詞。
思路和代碼我們只需要每次從當前字符串中進行一次分割,該分割保證前一部分為字典中的一個單詞,然后我們將后一部分作為子字符串遞歸的傳入方法獲取子字符串的分割。
catsanddog
cat | sanddog
cat | sand | dog
cats | anddog
cats | and | dog
但是單純的遞歸會帶來超時的情況,尤其是當字典中的單詞出現(xiàn)大量包含的情況,如:[a,aa,aaa,aaaa],而輸入為aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
我們可以利用HashMap緩存來解決這個問題,其中key為子字符串,value為其分割的結(jié)果的列表。
private Map> cache = new HashMap >(); public List wordBreak(String s, List wordDict) { if(cache.containsKey(s)) return cache.get(s); List result = new ArrayList (); if(s.length()==0){ result.add(""); return result; } for(String word : wordDict){ if(s.startsWith(word)){ List subWords = wordBreak(s.substring(word.length()), wordDict); for(String subWord : subWords){ result.add(word + (subWord.isEmpty() ? "" :" ") + subWord); } } } cache.put(s, result); return result; }
想要了解更多開發(fā)技術(shù),面試教程以及互聯(lián)網(wǎng)公司內(nèi)推,歡迎關(guān)注我的微信公眾號!將會不定期的發(fā)放福利哦~
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/68643.html
摘要:銜接點在于的前后連貫,拼成所有的滿足條件的前后兩個要連續(xù)。遞歸問題,要記得設(shè)置終止退出條件設(shè)置成形式,就不需要過程中了,直接在此進行疊加累計應(yīng)用將一個連續(xù)序列分成所有元素可能的組合情況。重點明確不必要的地方,可以不用去進行計算。 題目闡述: 廣度搜索問題。 計算出所有可能的情況。 銜接點在于segs的前后連貫,拼成所有的滿足條件的segs 前后兩個seg要連續(xù)。 遞歸問題,要記得設(shè)置終...
摘要:所以現(xiàn)在里面應(yīng)該存可以使長度為所有可能的里的最后一個。有兩種寫法,一個就是直接寫成數(shù)組的形式,不能形成的。結(jié)束之后,第二步就是通過里面保存的,一步一步回溯找到所有結(jié)果。直接的會超時,考慮記憶化搜索。所以事先對排序。 Word Break 鏈接:https://leetcode.com/problems... 這種找一個詞由多個詞組成的題,是拿dp或者dfs來解,dp本質(zhì)上其實也是dfs...
摘要:題目要求相比于,要求返回所有的最短路徑。至于如何生成該有向圖,則需要通過廣度優(yōu)先算法,利用隊列來實現(xiàn)。將每一層的分別入棧。如果遇到則至該層結(jié)尾廣度優(yōu)先算法結(jié)束。通過這種方式來防止形成圈。 題目要求 Given two words (beginWord and endWord), and a dictionarys word list, find all shortest transfo...
摘要:存放過程中的所有集合為所有的結(jié)尾,則順序存放這個結(jié)尾對應(yīng)的中的所有存放同一個循環(huán)的新加入的,在下一個循環(huán)再依次對其中元素進行進一步的把首個字符串放入新,再將放入,并將鍵值對放入,進行初始化 Problem Given two words (start and end), and a dictionary, find all shortest transformation sequenc...
摘要:所以只要驗證滿足這個條件,我們則可以確定這個較長的字符串也是可分解的。同時,我們用數(shù)組記錄下字符串長度遞增時可分解的情況,以供之后使用,避免重復計算。當遍歷完這個詞典并找出所有以第一個字母開頭的詞以后,我們進入下一輪搜索。 Word Break I Given a string s and a dictionary of words dict, determine if s can ...
閱讀 2570·2021-09-30 10:00
閱讀 3505·2021-09-22 10:54
閱讀 6274·2021-09-07 10:28
閱讀 2957·2019-08-29 13:53
閱讀 753·2019-08-29 12:42
閱讀 968·2019-08-26 13:51
閱讀 1266·2019-08-26 13:32
閱讀 3029·2019-08-26 10:39