Leetcode 3316. Find Maximum Removals From Source String

  • [Leetcode 3316. Find Maximum Removals From Source String](#Leetcode 3316. Find Maximum Removals From Source String)
    • [1. 解题思路](#1. 解题思路)
    • [2. 代码实现](#2. 代码实现)

1. 解题思路

这一题思路上的话就是一个动态规划的题目,我们仿照lcs,考察每一个位置是否可以drop即可。

而关于lcs算法,网上有很多介绍文章,这里就不过多赘述了。

2. 代码实现

给出python代码实现如下:

python 复制代码
class Solution:
    def maxRemovals(self, source: str, pattern: str, targetIndices: List[int]) -> int:
        n, m = len(source), len(pattern)
        targets = set(targetIndices)

        @lru_cache(None)
        def dp(i, j):
            if j >= m:
                return len([idx for idx in range(i, n) if idx in targets])
            if i >= n:
                return -math.inf
            if i in targets:
                if source[i] == pattern[j]:
                    return max(dp(i+1, j+1), 1 + dp(i+1, j))
                else:
                    return 1 + dp(i+1, j)
            else:
                if source[i] == pattern[j]:
                    return dp(i+1, j+1)
                else:
                    return dp(i+1, j)
                
        remove = dp(0, 0)
        return remove if remove != -math.inf else 0

提交代码评测得到:耗时2217ms,占用内存725MB。

相关推荐
师太,答应老衲吧3 小时前
SQL实战训练之,力扣:2020. 无流量的帐户数(递归)
数据库·sql·leetcode
姜西西_8 小时前
动态规划 之 斐波那契数列模型 算法专题
算法·动态规划
passer__jw76710 小时前
【LeetCode】【算法】208. 实现 Trie (前缀树)
算法·leetcode
益达爱喝芬达11 小时前
力扣11.3
算法·leetcode
passer__jw76711 小时前
【LeetCode】【算法】406. 根据身高重建队列
算法·leetcode
__AtYou__12 小时前
Golang | Leetcode Golang题解之第535题TinyURL的加密与解密
leetcode·golang·题解
远望樱花兔12 小时前
【d63】【Java】【力扣】141.训练计划III
java·开发语言·leetcode
迃-幵12 小时前
力扣:225 用队列实现栈
android·javascript·leetcode
九圣残炎12 小时前
【从零开始的LeetCode-算法】3254. 长度为 K 的子数组的能量值 I
java·算法·leetcode
vir0213 小时前
找出目标值在数组中的开始和结束位置(二分查找)
数据结构·c++·算法·leetcode