leetcode 力扣 139 单词拆分

79 阅读1分钟

lc139_1.jpeg

lc139_2.jpeg

dog之所以false,是因为and被拆分后,s中可用的部分只剩下ogdp数组中用dfalse来确保这一点,而otrue预示着可以从o开始被拆分

public boolean wordBreak(String s, List<String> wordDict) {
        Set<String> wordDictSet = new HashSet(wordDict);
        int n = s.length();
        boolean[] dp = new boolean[n + 1];
        dp[0] = true;

        for (int i = 1; i <= n; i++) {
            for (int j = 0; j < i; j++) {
                if (dp[j] && wordDictSet.contains(s.substring(j, i))) {
                    dp[i] = true;
                    break;
                }
            }
        }

        return dp[n];
    }