zoukankan      html  css  js  c++  java
  • [LeetCode] Word Break

    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".

    Solution:

    LTE Code:

    string srcStr;
    unordered_set<string> dic;
    
    bool word_break(int start)
    {
        //cout << "Start with " << start << endl;
        if(start >= srcStr.length()) 
            return true;
        for(int i = start;i < srcStr.length();i++)
        {
            string curStr = srcStr.substr(start, i - start + 1);
            if(dic.find(curStr) != dic.end())
            {
                //return word_break(i+1); //The reason is that if current recursion return false, doest not mean the 
                //break should fail, we need to check other combinations.
                if(word_break(i + 1)) 
                    return true;
                else 
                    continue;
            }
            else continue;
        }
    
        return false;
    }
    
    bool wordBreak(string s, unordered_set<string> &dict) {
            srcStr = s;
            dic = dict;
            return word_break(0);
        }

    AC Code:

    string srcStr;
    unordered_set<string> dic;
    int visited[1000][1000];
    int checked[1000];
    
    string srcStr;
    unordered_set<string> dic;
    int visited[1000][1000];
    int checked[1000];
    
    bool word_break(int start)
    {
        //cout << "Start with " << start << endl;
        if(start >= srcStr.length()) 
            return true;
        for(int i = start;i < srcStr.length();i++)
        {
            string curStr = srcStr.substr(start, i - start + 1);
    
            int finded = 0;
            if(visited[start][i] == 1)
                finded = true;
            else if(visited[start][i] == 2)
                finded = false;
            else
            {
                finded = (dic.find(curStr) != dic.end()) ? 1 : 2;
                visited[start][i] = finded;
            }
    
            if(finded == 1)
            {
                if(checked[i + 1] == 1)
                    return true;
                else if(checked[i + 1] == 2)
                    continue;
                else 
                {
                    checked[i + 1] = word_break(i + 1) ? 1 : 2;
                    if(checked[i + 1] == 1)
                        return true;
                    else
                        continue;
                }
            }
            else continue;
        }
    
        return false;
    }
    
    bool wordBreak(string s, unordered_set<string> &dict) {
            srcStr = s;
            dic = dict;
            for(int i = 0;i < 1000;i++)
                memset(visited[i], 0, sizeof(int) * 1000);
            memset(checked, 0, sizeof(int) * 1000);
    
            if(s.length() > 1000) return false;
    
            return word_break(0);
        }

  • 相关阅读:
    PHP数组(数组正则表达式、数组、预定义数组)
    面向对象。OOP三大特征:封装,继承,多态。 这个讲的是【封存】
    uvalive 3938 "Ray, Pass me the dishes!" 线段树 区间合并
    LA4329 Ping pong 树状数组
    HDU 1257 最少拦截系统
    HDU 1260 Tickets
    codeforce 621D
    codeforce 621C Wet Shark and Flowers
    codeforce 621B Wet Shark and Bishops
    codeforce 621A Wet Shark and Odd and Even
  • 原文地址:https://www.cnblogs.com/changchengxiao/p/3825378.html
Copyright © 2011-2022 走看看