Q:

给定一个非空字符串 s 和一个包含非空单词列表的字典 wordDict,在字符串中增加空格来构建一个句子,使得句子中所有的单词都在词典中。返回所有这些可能的句子。

说明:

分隔时可以重复使用字典中的单词。
你可以假设字典中没有重复的单词。
示例 1:

输入:
s = “catsanddog”
wordDict = [“cat”, “cats”, “and”, “sand”, “dog”]
输出:
[
“cats and dog”,
“cat sand dog”
]
示例 2:

输入:
s = “pineapplepenapple”
wordDict = [“apple”, “pen”, “applepen”, “pine”, “pineapple”]
输出:
[
“pine apple pen apple”,
“pineapple pen apple”,
“pine applepen apple”
]
解释: 注意你可以重复使用字典中的单词。
示例 3:

输入:
s = “catsandog”
wordDict = [“cats”, “dog”, “sand”, “and”, “cat”]
输出:
[]

A:

关键是要先用139的代码算一下给的字符串能不能被拆分为字典里的单词,不能直接返回。因为算是否能被拆分是O(N ^ 2),而本题要求的所有序列是O(N ^ 3),不先判断一下有一个全是’a’的用例是过不去的。。

C++:

  1. class Solution {
  2. public:
  3. vector<string> wordBreak(string s, vector<string>& wordDict) {
  4. vector<vector<string>> dp(s.size(),vector<string>());
  5. unordered_set<string> dic;
  6. for(auto& str:wordDict){
  7. dic.insert(str);
  8. }
  9. vector<bool> judge(s.size(),false);
  10. for(int i=0;i<s.size();++i){
  11. if(dic.count(s.substr(0,i+1))){judge[i]=true;}
  12. else{
  13. for(int j=0;j<=i;++j){
  14. if(judge[j] and dic.count(s.substr(j+1,i-j))){
  15. judge[i]=true;
  16. break;
  17. }
  18. }
  19. }
  20. }
  21. if(not judge.back()){return {};}
  22. //dp[i]表示s截止到i的可能分割出的句子
  23. for(int i=0;i<s.size();++i){
  24. for(int j=0;j<=i;++j){
  25. if(dic.count(s.substr(j,i-j+1))){
  26. string str2=s.substr(j,i-j+1);
  27. if(j==0){
  28. dp[i].push_back(str2);
  29. continue;
  30. }
  31. if(not judge[j-1]){continue;}
  32. for(auto& str1:dp[j-1]){
  33. dp[i].push_back(str1+" "+str2);
  34. }
  35. }
  36. }
  37. }
  38. return dp[s.size()-1];
  39. }
  40. };

python:

  1. class Solution:
  2. def wordBreak(self, s: str, WordDict):
  3. l=len(s)
  4. if not l:
  5. return 0
  6. dic={ x:1 for x in WordDict}
  7. #上一题代码拿来用
  8. judge=[0 for i in range(l)]
  9. judge[0]=int(s[0] in dic) #i==0递推基础
  10. for i in range(1,l): #i==1开始遍历
  11. if s[:i+1] in dic:
  12. judge[i]=1
  13. else:
  14. for j in range(i):
  15. if judge[j] and s[j+1:i+1] in dic:
  16. judge[i]=1
  17. break
  18. print(judge)
  19. if not judge[-1]:
  20. return []
  21. #开始算本题所求的序列
  22. dp=[[]for i in range(l)] #dp[i]是一个列表,存储不同的s[1,i]闭区间的有效拆分序列
  23. if s[0] in dic:
  24. dp[0].append(s[0]) #递推起始状态
  25. for i in range(1,l): #从i==1开始自底向上递推
  26. if s[:i+1] in dic: #s[0:i+1]本身就在字典里则加入解集
  27. dp[i].append(s[:i+1])
  28. for cut in range(i): #进行切分,符合条件的加入解集
  29. if s[cut+1:i+1] in dic and judge[cut]:
  30. #cut前面的子问题有解且cut之后到i的字符串在字典中
  31. for x in dp[cut]: #x为字符串
  32. dp[i].append(x+' '+s[cut+1:i+1])
  33. #把dp[cut]中的每个解加上cut后的字符串,插入dp[i]的解集
  34. # print(dp)
  35. return dp[-1]

140. 单词拆分 II的更多相关文章

  1. Java实现 LeetCode 140 单词拆分 II(二)

    140. 单词拆分 II 给定一个非空字符串 s 和一个包含非空单词列表的字典 wordDict,在字符串中增加空格来构建一个句子,使得句子中所有的单词都在词典中.返回所有这些可能的句子. 说明: 分 ...

  2. [LeetCode] 140. 单词拆分 II

    题目链接 : https://leetcode-cn.com/problems/word-break-ii/ 题目描述: 给定一个非空字符串 s 和一个包含非空单词列表的字典 wordDict,在字符 ...

  3. Java实现 LeetCode 140 单词拆分II

    class Solution { public List<String> wordBreak(String s, List<String> wordDict) { List&l ...

  4. [LeetCode] 140. Word Break II 单词拆分II

    Given a non-empty string s and a dictionary wordDict containing a list of non-empty words, add space ...

  5. leetcode 140 单词拆分2 word break II

    单词拆分2,递归+dp, 需要使用递归,同时使用记忆化搜索保存下来结果,c++代码如下 class Solution { public: //定义一个子串和子串拆分(如果有的话)的映射 unorder ...

  6. 算法——单词拆分 II

    给定一个非空字符串 s 和一个包含非空单词列表的字典 wordDict,在字符串中增加空格来构建一个句子,使得句子中所有的单词都在词典中.返回所有这些可能的句子. 链接: leetcode. 解题思路 ...

  7. [Swift]LeetCode140. 单词拆分 II | Word Break II

    Given a non-empty string s and a dictionary wordDict containing a list of non-empty words, add space ...

  8. [LeetCode] 139. Word Break 单词拆分

    Given a non-empty string s and a dictionary wordDict containing a list of non-empty words, determine ...

  9. leetcode 139. Word Break 、140. Word Break II

    139. Word Break 字符串能否通过划分成词典中的一个或多个单词. 使用动态规划,dp[i]表示当前以第i个位置(在字符串中实际上是i-1)结尾的字符串能否划分成词典中的单词. j表示的是以 ...

随机推荐

  1. pip 配置国内源

      网上已经有很多人介绍了,我写在这儿就是为了找起来方便. https://www.cnblogs.com/schut/p/10410087.html 这篇博客还是很有意思的,他介绍了两种方法.可以一 ...

  2. 用R实现范式编程

    面向函数范式编程(Functional programming) 模拟简单的随机过程 模拟一个简单的随机过程:从N~(0,1)标准正态分布中产生100个随机值,反复5次得到一个list,再以每个lis ...

  3. 嵊州D6T2 城市 city

    城市 city [问题描述] 众所周知,why 是czyz 王国的国王. czyz 王国一共有n 个城市,每个城市都有一条道路连向一个城市(可能连向这个城市自己). 同时,对于每一个城市,也只有一条道 ...

  4. c#实现把异常写入日志示例(异常日志)

    将异常写到日志文件中,可以在调试程序的时候知道程序发生过哪些异常,并且可以知道异常发生的位置.这点对需要进行长时间运行并调试的程序尤为有效. /// <summary> /// 将异常打印 ...

  5. HTTP代理服务器搭建

    由于在某些特定场景下,我们的外网访问会受到限制,如果有一些访问需求的话就需要一个代理作为中转了. 首先需要一台机器作为中转的服务器,这时候当然要去阿里云买一台啦.操作系统一定要选Linux,我使用的是 ...

  6. MarkDown图文编辑系列教程(二)

    一.写在前面 引言 本文是我写的MarkDown系列教程的第二篇,前一篇的地址:MarkDown图文编辑系列教程(一) 读完本篇,你将获得 学会使用markdown语法进行:区块引用(一种常用的引用格 ...

  7. CentOS进行yum操作时不能访问国外镜像的解决方案

    1. 例如执行yum update,经常报错“Cound not resolve host: xxxxx”,一般都是yum源是使用的国外镜像,国内访问很不好.这时可以将源手动替换为国内的清华大学源,或 ...

  8. python笔记06

    python笔记06 数据类型 上个笔记内容补充 补充 列表 reverse,反转. v1 = [1,2,3111,32,13] print(v1) v1.reverse() print(v1) v1 ...

  9. 假期学习【九】首都之窗百姓信件爬取代码优化以及处理 2020.2.7 Python

    今天对爬取程序进行了优化,修正了错误. 遇到了两个问题与错误: 1.忘记了对文件的读写设置格式,导致导入Hive数据库无法正常显示以及写入. 2.文件的读写操作有误导致数据量仅有应该有的1/2 不完整 ...

  10. shell变量内字符替换和变量字符修改

    vi test.sh a= #将${a}里的第一个123替换为321 b=${a//}; echo "echo variable a" echo $a echo "ech ...