Link
题目简述
题目让我们把字符串B通过插入,删除,修改一个字符三种方式变化为字符A,求最少操作次数。此处求的是最值,考虑用动态规划
定义状态:
dp [ i ] [ j ] 表示使B [ 1 ~ j ] 与 A [ 1 ~ i ]变相等要花的值,最后的答案即为dp [ lenb ] [ lena ]
状态转移:
所有的动态规划题都是从已知推向未知的过程。因此我在思考一个dp时,总是从最后一个阶段着点。
对于此题,首先是边界:
①i==0时,即a为空,那么对应的dp[j][0]的值就为i:减少i个字符,使b转化为a
②j==0时,即b为空,那么对应的dp[0][i]的值就为j:增加j个字符,使b转化为a
if 当A[ i ]==B[ j ]时,如果这两位相等,意思是使 i 位与 j 位相等不需要任何代价,只需要计算使 i - 1 位与 j - 1 位相等的代价