文章目录
题目描述
题解思路
我们使用一个数组记录字符串s在[0, i)区间能否使用wordDict组成
我们使用左右指针遍历字符串s的子串,左指针 j 为子串的左端点下标,右指针 i 为右端点下标的下一个
遍历过程中如果字符串s在[0, j)区间子串能被wordDict组成,则检查字符串s在[j, i)区间子串是否在wordDict中,如果在,则表明字符串s在[0, i)区间子串能被wordDict组成
题解代码
go
func wordBreak(s string, wordDict []string) bool {
n := len(s)
wordMap := make(map[string]struct{}, len(wordDict))
for _, word := range wordDict {
wordMap[word] = struct{}{}
}
// s的[0, i)区间子串是否能用wordDict组成
f := make([]bool, n + 1)
f[0] = true
// 遍历字符串的所有子串,注意右端点需要从左到右遍历,因为我们的计算需要用到右端点之前从零开始的子串是否能被wordDict组成,也就是我们依赖了f数组中[0,i)的数据
for i := 1; i <= n; i++ {
for j := 0; j < i; j++ {
if f[j] {
// 如果左端点左边的子串可以被wordDict组成,则检查左端点到右端点能否被wordDict组成
if _, ok := wordMap[s[j:i]]; ok {
f[i] = true
break
}
}
}
}
return f[n]
}