码迷,mamicode.com
首页 > 其他好文 > 详细

动态规划之140 Word Break2

时间:2018-12-21 22:55:38      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:nbsp   length   深度   last   int   info   linked   http   bre   

这是一题不太明显的动态规划,主要考察的应该是深度优先搜索。

static LinkedList<String> list = new LinkedList<String>();
    static ArrayList<String> res=new ArrayList<String>();
    public ArrayList<String> wordBreak(String s, List<String> set) {
        list.clear();
        res.clear();
        if (s == null || s.length() == 0)
            return res;
        if (wordBreakcheck(s, set))
            dfs(s, set);
        return res;
    }

    private void dfs(String s, List<String> set) {
        if (s==null||s.length()==0) {
            StringBuilder sb = new StringBuilder();
            for (String ss : list) {
                sb.append(ss);
                sb.append(" ");
            }
            res.add(sb.toString().trim());
            return;
        }
        for (int i = 1; i <= s.length(); i++) {
            String str=s.substring(0, i);
            if (set.contains(str)) {
                list.add(str);
                //s = s.substring(i, s.length());
                dfs(s.substring(i, s.length()), set);
                list.pollLast();
            }
        }
    }
    
    public boolean wordBreakcheck(String s, List<String> set) {
        if (s == null || s.length() == 0)
            return true;
        boolean[] res = new boolean[s.length() + 1];
        res[0] = true;
        for (int i = 0; i < s.length(); i++) {
            StringBuilder str = new StringBuilder(s.substring(0, i + 1));
            for (int j = 0; j <= i; j++) {
                if (res[j] && set.contains(str.toString())) {
                    res[i + 1] = true;
                    break;
                }
                str.deleteCharAt(0);
            }
        }
        return res[s.length()];
    }

技术分享图片

if (set.contains(str)) {
list.add(str);
dfs(s.substring(i, s.length()), set);
list.pollLast();
}

 

if (set.contains(str)) {
list.add(str);
s = s.substring(i, s.length());
dfs(s, set);
list.pollLast();
}

 以上两种写法是完全不一样的,已经多次翻车。第一种写法,dfs函数执行完后s然后是没有切割的字符串,而第二种写法是dfs执行完后s已经是切割完的了。

 

动态规划之140 Word Break2

标签:nbsp   length   深度   last   int   info   linked   http   bre   

原文地址:https://www.cnblogs.com/clarencezzh/p/10158829.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!