[712][中等][动态规划] 两个字符串的最小ASCII删除和
最后更新于
这有帮助吗?
最后更新于
这有帮助吗?
给定两个字符串s1, s2,找到使两个字符串相等所需删除字符的ASCII值的最小和。
示例 1:
示例 2:
注意:
0 < s1.length, s2.length <= 1000。
所有字符串中的字符ASCII值在[97, 122]之间。
与583题不同的是, 本题除了要寻找到不再是最长的公共子序列, 而是这些公共子序列中两个字符串中删除的字符的ASCII编码值之和最小, 换句话说, 就是寻找所有最长公共子序列中, ASCII编码值最大的一个子序列.
因此动态规划的状态矩阵dp[i][j]
定义为s1
字符串的前i个字符和s2
字符串前j个字符公共子序列对应的ASCII编码之和的最大值.
在求dp[i][j]
时, 如果s1[i] == s2[j]
, 说明公共子序列又可以延长一位, dp[i][j] = dp[i - 1][j - 1] + ord(s1[i - 1])
.
如果s1[i] != s2[j]
, 我们从dp[i - 1][j]
和dp[i][j - 1]
之间选取更大的值.
本题与题目类似, 操作都是通过删除两个字符串中的字符, 使得两个字符串相同. 其实等价于寻找最长公共子序列.