Minimum distance between strings
DP; Medium;
1. Link
2. 描述
给定两个长度相等的,由小写字母组成的字符串S1和S2,定义S1和S2的距离为两个字符串有多少个位置上的字母不相等。现在牛牛可以选定两个字母X1和X2,将S1中的所有字母X1均替换成X2。(X1和X2可以相同)牛牛希望知道执行一次替换之后,两个字符串的距离最少为多少。
示例1
输入:
复制返回值:
复制说明:
示例2
输入:
复制返回值:
复制说明:
备注:
3. 思路: 2D-DP
搭建26*26的2D table, row和column分别代表26个字母,dp[i][j]= string S1里面的char = 第i个字符时,string S2对应位置里面为第j个字符的个数。 例子: s1= "aab", s2= "bbc", 当s1的字符=‘a’ (i=0)时 s2的字符=‘b’ (j=1)的个数是2, 所以dp[0][1] = 2
遍历S1,把S1和S2的不同字符的个数加起来起来, distance = 不同字符个数+ S1和S2的字符长度差, 并且把dp table填充
遍历dp table的每一行, 并计算那一行的里面 最大的count - dp[i][i]的值, 即把这个char换成另外一个char时最大能减少的distance长度,Di
把每一行的最大能减少的distance长度对比,找到S1里面最大Di, 即 D_max
返回 distance -D_max
TIme: O(n + 26*26) = O(n)
Space: O(26*26) = O(1)
4. Coding
Last updated