代码随想录算法训练营第四十六天|139.单词拆分

leetcode 139 单词拆分

题目链接

139. 单词拆分 - 力扣(LeetCode)

做题过程

排列+完全背包

设置一个boolean[]即可。

关键在于条件的设置。

当前面一个为true,如果加上这个单词还是string的字串。那么依然为true.

解决方法

class Solution {
    public boolean wordBreak(String s, List<String> wordDict) {
        boolean[] dp = new boolean[s.length() + 1];
        dp[0] = true;

        for (int i = 1; i <= s.length(); i++) {
            for (String word : wordDict) {
                int len = word.length();
                if (i >= len && dp[i - len] && word.equals(s.substring(i - len, i))) {
                    dp[i] = true;
                    break;
                }
            }
        }
        return dp[s.length()];   
    }
}

你可能感兴趣的:(算法)