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

Word Break/Word Segment

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

标签:style   blog   color   os   art   cti   

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

标签:style   blog   color   os   art   cti   

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

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