news 2026/7/2 8:41:40

力扣139 单词拆分 java实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣139 单词拆分 java实现

139.单词拆分

给你一个字符串s和一个字符串列表wordDict作为字典。如果可以利用字典中出现的一个或多个单词拼接出s则返回true

注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。

示例 1:

输入:s = "leetcode", wordDict = ["leet", "code"]输出:true解释:返回 true 因为 "leetcode" 可以由 "leet" 和 "code" 拼接成。

示例 2:

输入:s = "applepenapple", wordDict = ["apple", "pen"]输出:true解释:返回 true 因为 "applepenapple" 可以由 "apple" "pen" "apple" 拼接成。 注意,你可以重复使用字典中的单词。

示例 3:

输入:s = "catsandog", wordDict = ["cats", "dog", "sand", "and", "cat"]输出:false

提示:

  • 1 <= s.length <= 300
  • 1 <= wordDict.length <= 1000
  • 1 <= wordDict[i].length <= 20
  • swordDict[i]仅由小写英文字母组成
  • wordDict中的所有字符串互不相同

该题也属于完全背包问题,字典中的物品可以重复使用。dp[n + 1]表示当前位置能否被 字典里的单词组成。每次遍历字典,则只需要判断和当前单词是否相同,或是取出长度为当前单词的长度的单词,判断是否相同,且前面单词是否已经能用词典表示。

public static void main(String[] args) { // 测试用 String s = "leetcode"; List<String> nums = new ArrayList<>(); nums.add("leet"); nums.add( "code"); System.out.println(wordBreak(s, nums)); } public static boolean wordBreak(String s, List<String> wordDict) { int n = s.length(); boolean[] dp = new boolean[n + 1]; for (int i = 0; i <= n; i++) { String target = s.substring(0, i); for (int j = 0; j < wordDict.size(); j++) { String temp = wordDict.get(j); if (temp.equals(target)){ dp[i] = true; break; } int m = temp.length(); if (i >= m){ String target1 = target.substring(i - m, i); if (target1.equals(temp) && dp[i - m]){ dp[i] = true; } } } } System.out.println(Arrays.toString(dp)); return dp[n]; }

以上为记录分享用,代码较差请见谅

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/25 19:28:26

大模型RAG架构演进详解:从Naive到Agentic的四代技术突破与应用实践

本文系统梳理了检索增强生成&#xff08;RAG&#xff09;架构的演进历程&#xff0c;详细对比了Naive RAG、Advanced RAG、Modular RAG和Agentic RAG四代架构的核心特点与技术突破。从基础三步流程发展到模块化设计和智能体协同&#xff0c;RAG技术通过创新解决了知识更新、语义…

作者头像 李华
网站建设 2026/6/30 11:04:48

口腔伤口可以用什么药物促进愈合

口腔生理环境特殊&#xff0c;伤口愈合需针对性护理&#xff0c;当前口腔健康领域虽有高露洁、佳洁士等国际企业布局护理产品&#xff0c;拜耳、葛兰素史克及国内云南白药、三金药业等深耕口腔用药&#xff0c;但深圳市华生元基因工程发展有限公司的相关产品在口腔伤口促愈领域…

作者头像 李华
网站建设 2026/6/26 16:42:51

MySQL索引精讲:从原理到实战,小白也能秒懂!

视频看了几百小时还迷糊&#xff1f;关注我&#xff0c;几分钟让你秒懂&#xff01;在日常开发中&#xff0c;我们经常会遇到 SQL 查询慢得像蜗牛的情况。明明数据量不大&#xff0c;却查个几秒钟甚至十几秒——这时候&#xff0c;MySQL 索引就是你最该检查的地方&#xff01;今…

作者头像 李华
网站建设 2026/6/26 16:42:16

基于单片机的语音识别控制灯

2方案论证 2.1方案论证 本次设计使用STC89C52单片机&#xff0c;它属于MCS-51系列&#xff0c;STC89C52是一个应用范围广泛的8位单片机&#xff0c;成本低是他的一大优势。STC89C52作为控制中心&#xff0c;他的功能是对专门的语音进行处理并接受芯片传输的指令&#xff0c;使用…

作者头像 李华
网站建设 2026/6/29 5:53:20

历时八年,微软XAML Studio正式开源

https://github.com/dotnet/XAMLStudio XAML 可以理解为 XML 面向UI的特定词汇&#xff08;对象、属性、事件、绑定&#xff09; .NET运行时支持。 XAML Studio 是微软 Garage 项目的一员&#xff0c;它能帮助您快速构建 UWP XAML 原型&#xff0c;并轻松复制到 Visual Stu…

作者头像 李华