当前位置: 首页 > news >正文

Leetcode 140 Word Break II

题意:给定一个string以及一个wordDict,要求返回一个vector<string> ,这个vector中的string都是word Dict中的组合

Input: s = “catsanddog”, wordDict = [“cat”,“cats”,“and”,“sand”,“dog”]
Output: [“cats and dog”,“cat sand dog”]

想法:backtracking, 想象一下每一轮你要干什么,首先拿wordDict中的每个单词去填写,如果对不上号,你就填下一个单词直到最后填到单词末尾就结束了。

class Solution {
public:vector<string> ret;vector<string> wordBreak(string s, vector<string>& wordDict) {dfs(s, "", 0 , wordDict);return ret;}void dfs(string& s, string cur, int st, vector<string>& wordDict) {if (st == s.size()) {cur.pop_back();ret.push_back(cur);}for(auto word : wordDict) {if(st + word.size() <= s.size()) {if(word == s.substr(st, word.size())) {string temp = cur;cur += word;cur += " ";dfs(s, cur, st+word.size(), wordDict);cur = temp;}}}}
};

时间复杂度是指数级别的,递归栈空间是O(n)

http://www.lryc.cn/news/470742.html

相关文章:

  • 文理学院数据库应用技术实验报告0
  • Bootstrap 4 按钮
  • 【笔记】LLM位置编码之标准位置编码
  • 环 境 配 置
  • 理解dbt artifacts及其实际应用
  • 100种算法【Python版】第15篇——KMP算法
  • 【软件工程】软件项目管理/工程项目管理复习资料
  • C语言基础题(大合集2)
  • Stable Diffusion视频插件Ebsynth Utility使用方法
  • Ubuntu忘记密码
  • 使用Python实现深度学习模型:智能极端天气事件预测
  • cJson函数解析
  • 基于SSM+微信小程序的跑腿平台管理系统(跑腿3)
  • mit6824-02-Lab1:MapReduce分布式实现
  • 【NOIP普及组】 装箱问题
  • Flutter主题最佳实践
  • 计算机网络:网络层 —— IPv4 数据报的首部格式
  • MySQL 之 索引
  • 手动探针台的用途及组成部分
  • ❤️算法笔记❤️-(每日一刷-5、最长回文串)
  • nginx 路径匹配,关于“/“对规则的影响
  • 安全知识见闻-网络安全热门证书
  • Pandabuy事件警示:反向海淘品牌如何规避风险
  • 【纯血鸿蒙】安装hdc工具
  • TensorFlow面试整理-给定一个任务(如图像分类、文本分类),如何从头构建一个TensorFlow模型?
  • unity中出现一些莫名其妙的问题
  • Python爬虫-汽车投诉排行榜单数据
  • [C++][数据结构][哈希表]详细讲解
  • Android Gradle
  • Vue2自定义指令及插槽