【139.单词拆分】

目录

  • 一、题目解析
  • 二、算法原理
  • 三、代码实现

一、题目解析

【139.单词拆分】_第1张图片

二、算法原理

【139.单词拆分】_第2张图片

三、代码实现

class Solution {
public:
    bool wordBreak(string s, vector<string>& wordDict) 
    {
        int n = s.size();
        unordered_set<string> hash;
        for (auto x : wordDict) hash.insert(x);
        vector<bool> dp(n + 1);
        dp[0] = true;
        s = ' ' + s;
        for (int i = 1; i <= n; i++)
        {
            for (int j = i; j >= 1; j--)
            {
                if (dp[j - 1] && hash.count(s.substr(j, i - j + 1)))
                {
                    dp[i] = true;
                    break;
                }
            }
        }
        return dp[n];

    }
};

你可能感兴趣的:(动态规划,动态规划,c++,leetcode,算法)