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

【划分型 DP-最优划分】力扣2707. 字符串中的额外字符

给你一个下标从 0 开始的字符串 s 和一个单词字典 dictionary 。你需要将 s 分割成若干个 互不重叠 的子字符串,每个子字符串都在 dictionary 中出现过。s 中可能会有一些 额外的字符 不在任何子字符串中。

请你采取最优策略分割 s ,使剩下的字符 最少 。

示例 1:
输入:s = “leetscode”, dictionary = [“leet”,“code”,“leetcode”]
输出:1
解释:将 s 分成两个子字符串:下标从 0 到 3 的 “leet” 和下标从 5 到 8 的 “code” 。只有 1 个字符没有使用(下标为 4),所以我们返回 1 。

示例 2:
输入:s = “sayhelloworld”, dictionary = [“hello”,“world”]
输出:3
解释:将 s 分成两个子字符串:下标从 3 到 7 的 “hello” 和下标从 8 到 12 的 “world” 。下标为 0 ,1 和 2 的字符没有使用,所以我们返回 3 。

提示:
1 <= s.length <= 50
1 <= dictionary.length <= 50
1 <= dictionary[i].length <= 50
dictionary[i] 和 s 只包含小写英文字母。
dictionary 中的单词互不相同。

class Solution {
public:
    int minExtraChar(string s, vector<string>& dictionary) {
        int n = s.size();
        vector<int> dp(n+1);
        for(int i = n-1; i >= 0; i--){
            dp[i] = dp[i+1] + 1;
            for(auto& word : dictionary){
                if(s.compare(i, word.size(), word) == 0){
                    dp[i] = min(dp[i], dp[i+word.size()]);
                }
            }
        }
        return dp[0];
    }
};

时间复杂度:O(N∗M∗K)
空间复杂度:O(N)

我们定义一个动态数组dp[i],代表从dp[i,…,n-1]中未匹配的字符数量。我们倒序遍历,在每一次遍历的开始,我们需要初始化dp[i],dp[i]的初始值可以由dp[i+1]+1状态转移而来。然后接下来我们通过遍历字典里的单词,s.compare(i, word.size(), word) == 0的含义是我们从s[i]开始的长度为word.size()的字符串是否和字典的单词匹配,如果匹配的话,并且dp[i+word.size()]小于dp[i],就更新dp[i]为dp[i+word.size()]。

最后返回dp[0],代表从字符串s的最少未匹配字符。


http://www.kler.cn/a/389631.html

相关文章:

  • 服务器一次性部署One API + ChatGPT-Next-Web
  • 1.7 ChatGPT:引领AI对话革命的致胜之道
  • Elasticsearch 和arkime 安装
  • 使用 Java 和 FreeMarker 实现自动生成供货清单,动态生成 Word 文档,简化文档处理流程。
  • 【算法】算法基础课模板大全——第一篇
  • 【网络协议】RFC3164-The BSD syslog Protocol
  • 解决程序因缺少xinput1_3.dll无法运行的有效方法,有效修复丢失xinput1_3.dll
  • WPF的<ContentControl>控件
  • 常用的损失函数pytorch实现
  • 批量清除Word Excel PPT文件打开密码
  • 让redis一直开启服务/自动启动
  • wordpress站外调用指定ID分类下的推荐内容
  • i2c-tools 4.3 for Android 9.0
  • stm32 ADC实例解析(3)-多通道采集互相干扰的问题
  • PySimpleGUI库和pymysql库
  • 探索计算机互联网的奇妙世界:从基础到前沿的无尽之旅
  • 2024 年 Java 面试正确姿势(1000+ 面试题附答案解析)
  • 算法学习第一弹——C++基础
  • Hive简介 | 体系结构
  • 青训3_1110_01 构造特定数组的逆序拼接
  • 性能飙升!时间序列+预训练强强联合,轻松迈入顶刊门槛!
  • conan2 c/c++包管理菜鸟入门
  • 使用MethodChannel与原生程序通信
  • PyQt5超详细教程终篇
  • 【Leecode】Leecode刷题之路第46天之全排列
  • InnoDB存储引擎对MVCC的实现