单词拆分

题目链接:(https://leetcode-cn.com/explore/interview/card/top-interview-quesitons-in-2018/275/string/1138/)


class Solution {
    public boolean wordBreak(String s, List<String> wordDict) {
        boolean[] count = new boolean[s.length() + 1];
        
            count[0] = true;
            for(int j = 1;j <= s.length();j++){
                for(int i = 0;i < j;i++){
                    // 这边是一个适配的理念,只要找到一个就立即跳出底层循环从当前j         处继续往后找。因为可以使用无限次数,所以其实这是一个背包问题。
                    if(count[i] && wordDict.contains(s.substring(i,j))){
                        count[j] = true;
                        break;
                    }
                }
            }
        
        return count[s.length()];
    }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容