首页 > 其他 > 详细

Word Break/Word Segment

时间:2014-07-01 23:43:19      阅读:358      评论:0      收藏:0      [点我收藏+]

Given a string s and a dictionary of words dict, determine if s can be segmented into a space-separated sequence of one or more dictionary words.

For example, given
s = "leetcode",
dict = ["leet", "code"].

Return true because "leetcode" can be segmented as "leet code".

Dynamic programming。用一个table记录下0~i-1是否符合要求。注意一开始的table[0]=true,以及table长度为输入字符串长度加一。Loop 0~s.length()-1,只能从table[i]=true的地方开始,因为那之前都是匹配的才能接着匹配。

public class Solution {
    public boolean wordBreak(String s, Set<String> dict) {
        int strlen=s.length();
        boolean [] table=new boolean[strlen+1];
        table[0]=true;//begin is always true, so we can start the loop
        for(int i=0;i<strlen;i++){
            if(!table[i])// 0~i-1 are not words
                continue;
            for(String word: dict){
                int len=word.length();
                int end=i+len-1;
                if(end>strlen-1)
                    continue;
                if(table[end+1])//already match at this position
                    continue;
                if(s.substring(i,end+1).equals(word)){
                    table[end+1]=true;
                }
            }
        }
        return table[strlen];
    }
}

 

Word Break/Word Segment,布布扣,bubuko.com

Word Break/Word Segment

原文:http://www.cnblogs.com/qingyezi/p/3816404.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!