leetcode 140. Word Break II ----- java
Given a string s and a dictionary of words dict, add spaces in s to construct a sentence where each word is a valid dictionary word.
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"].
139题的延伸题,需要的出所有结果。
1、递归,仍旧超时。
public class Solution {
    String[] result;
    List list;
    public List<String> wordBreak(String s, Set<String> wordDict) {
        int len = s.length(),maxLen = 0;
        result = new String[len];
        list = new ArrayList<String>();
        for( String str : wordDict ){
            maxLen = Math.max(maxLen,str.length());
        }
        helper(s,0,wordDict,maxLen,0);
        return list;
    }
    public void helper(String s,int pos,Set<String> wordDict,int maxLen,int count){
        if( pos == s.length() ){
            String str = result[0];
            for( int i = 1 ; i<count-1;i++){
                str =str+ " "+result[i];
            }
            if( count > 1)
                str = str+" "+result[count-1];
            list.add(str);
        }
        int flag = 0;
        for( int i = pos;pos - i<maxLen && i<s.length();i++){
            if( wordDict.contains( s.substring(pos,i+1) )){
                result[count] = s.substring(pos,i+1);
                helper(s,i+1,wordDict,maxLen,count+1);
                flag = 1;
            }
        }
    }
}
2、加入提前判断是否存在答案(即上一题的结论)就可以了。
public class Solution {
    String[] result;
    List list;
    public List<String> wordBreak(String s, Set<String> wordDict) {
        int len = s.length(),maxLen = 0;
        result = new String[len];
        list = new ArrayList<String>();
        for( String str : wordDict ){
            maxLen = Math.max(maxLen,str.length());
        }
        boolean[] dp = new boolean[len];
        for( int i = 0 ;i<len;i++){
            for( int j = i;j>=0 && i-j<maxLen;j-- ){
                if( ( j == 0 || dp[j-1] == true ) && wordDict.contains(s.substring(j,i+1)) ){
                    dp[i] = true;
                    break;
                }
            }
        }
        if( dp[len-1] == false)
            return list;
        helper(s,0,wordDict,maxLen,0);
        return list;
    }
    public void helper(String s,int pos,Set<String> wordDict,int maxLen,int count){
        if( pos == s.length() ){
            String str = result[0];
            for( int i = 1 ; i<count-1;i++){
                str =str+ " "+result[i];
            }
            if( count > 1)
                str = str+" "+result[count-1];
            list.add(str);
        }
        int flag = 0;
        for( int i = pos;pos - i<maxLen && i<s.length();i++){
            if( wordDict.contains( s.substring(pos,i+1) )){
                result[count] = s.substring(pos,i+1);
                helper(s,i+1,wordDict,maxLen,count+1);
                flag = 1;
            }
        }
    }
}
leetcode 140. Word Break II ----- java的更多相关文章
- [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 ... 
- Java for LeetCode 140 Word Break II
		Given a string s and a dictionary of words dict, add spaces in s to construct a sentence where each ... 
- Leetcode#140 Word Break II
		原题地址 动态规划题 令s[i..j]表示下标从i到j的子串,它的所有分割情况用words[i]表示 假设s[0..i]的所有分割情况words[i]已知.则s[0..i+1]的分割情况words[i ... 
- leetcode 139. Word Break 、140. Word Break II
		139. Word Break 字符串能否通过划分成词典中的一个或多个单词. 使用动态规划,dp[i]表示当前以第i个位置(在字符串中实际上是i-1)结尾的字符串能否划分成词典中的单词. j表示的是以 ... 
- 140. Word Break II(hard)
		欢迎fork and star:Nowcoder-Repository-github 140. Word Break II 题目: Given a non-empty string s and a d ... 
- 【LeetCode】140. Word Break II
		Word Break II Given a string s and a dictionary of words dict, add spaces in s to construct a senten ... 
- [Leetcode Week9]Word Break II
		Word Break II 题解 题目来源:https://leetcode.com/problems/word-break-ii/description/ Description Given a n ... 
- 【leetcode】Word Break II
		Word Break II Given a string s and a dictionary of words dict, add spaces in s to construct a senten ... 
- 【LeetCode】140. Word Break II 解题报告(Python & C++)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 递归求解 日期 题目地址:https://leetc ... 
随机推荐
- EntLib Unity父类的依赖注入问题
			Unity的注入有3种方式:构造函数.[Dependency]属性.[InjectionMethod]方法.这3种方式涉及到的interface或class都会去Registrations里找,找不到 ... 
- [USACO精选] 第三章 排序
			#9 重排干草 2014-02-12 QAQ这么快居然开学了,这么来说时间越来越少了…开学第二天,作业不多,赶紧抽出时间把这道想了很久的题给搞定……真的想了很久,其实看了解题也想了很久,我觉得我等数学 ... 
- C++全局变量的声明和定义
			(1)编译单元(模块) 在VC或VS上编写完代码,点击编译按钮准备生成exe文件时,编译器做了两步工作: 第一步,将每个.cpp(.c)和相应的.h文件编译成obj文件: 第二步,将工程中所有 ... 
- SharePoint开发 - 自定义导航菜单(一)菜单声明与配置
			博客地址 http://blog.csdn.net/foxdave 本篇描述自定义sharepoint菜单的一种方式,自定义菜单适用于一些门户等需求的网站 自定义的菜单有自己的数据源,可以是数据表,可 ... 
- PHP笔记(一)
			1. public 表示全局,类内部外部子类都可以访问:private表示私有的,只有本类内部可以使用:protected表示受保护的,只有本类或子类或父类中可以访问: 2. ==是包括变量值与类型完 ... 
- 《day18_String练习_基本类型包装类_集合入门》
			package cn.itcast.api.String.test; public class StringTest_1 { public static void main(String[] args ... 
- java.util 集合框架集合
			java的集合框架为程序提供了一种处理对象组的标准方式.设计了一系列标准泛型接口: ⑴Collection ()接口,扩展了Iterable接口,位于集合层次结构的顶部,因此所有的集合都实现Colle ... 
- 毕向东day01笔记--dos-jdk-jre-环境变量等
			1.常用的dos命令,md,rd,dir,c:(进入C盘),del,set classpath 2.JDK和JRE之间的区别: JDK包含JER,JRE包含JVM. 3.环境变量的配置,静态配置--b ... 
- iOS 设计模式之工厂模式
			iOS 设计模式之工厂模式 分类: 设计模式2014-02-10 18:05 11020人阅读 评论(2) 收藏 举报 ios设计模式 工厂模式我的理解是:他就是为了创建对象的 创建对象的时候,我们一 ... 
- WPF如何实现类似iPhone界面切换的效果(转载)
			WPF如何实现类似iPhone界面切换的效果 (version .1) 转自:http://blog.csdn.net/fallincloud/article/details/6968764 在论坛上 ... 
