139. Word Break - medium

这道题做的很值。
题不难,但是考察点很明确。
做DP的最大问题就是用递归,忘记用table来写。然后不停重复计算,exponential的运算增长,直接就爆了。这道题之所以是medium估计也是考这个的。

这个是典型的时间会爆掉的代码:

public class Solution {
    public boolean wordBreak(String s, Set<String> wordDict) {
        if(s == null || s.length() == 0)    throw new IllegalArgumentException("Invalid Input");
        int len = s.length();
        for(int i=1; i<=s.length(); i++) {
            String str = s.substring(0,i);
            if(wordDict.contains(str) && (i==len || wordBreak(s.substring(i,len), wordDict)))
                return true;
        }
        return false;
    }
}

用DP做的代码:
没什么好说的。

public class Solution {
    public boolean wordBreak(String s, Set<String> wordDict) {
        boolean[] mem = new boolean[s.length() + 1];
        mem[0] = true;
        for (int i=1; i<=s.length(); i++) {
            for (int j=0; j<i; j++) {
                if (mem[j] && wordDict.contains(s.substring(j,i))) {
                    mem[i] = true;
                    break;
                }
            }
        }
        return mem[s.length()];
    }
}

重复计算是DP里面用递归的大忌,这种一般要用top-down,memory做table。
不能重复计算,不能重复计算,不能重复计算!重要的事情说三遍!
============
much more effective at night.
How to block the sunshine during the day?
I will try to coding in my closet tomorrow : )

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,364评论 0 33
  • 一、源题QUESTION 74View the Exhibit. You want to create a tab...
    猫猫_tomluo阅读 5,646评论 0 1
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,777评论 18 399
  • LeetCode 刷题随手记 - 第一部分 前 256 题(非会员),仅算法题,的吐槽 https://leetc...
    蕾娜漢默阅读 18,288评论 2 36
  • 由于工作性质原因,接触很多国外文化和思想; 对于国产电影,很少会去电影院看。想到各种广告的植入,各种主题的...
    June88阅读 2,472评论 0 0

友情链接更多精彩内容