思路:为使word1和word2单词相同,需要将两个单词都变成最长公共子序列,我们首先求得两个单词的的最长公共子序列的长度,然后单词长度减去最长公共子序列长度即可。
class Solution {
public:
int minDistance(string word1, string word2) {
int m=word1.size(),n=word2.size();
vector<vector<int>>dp(m+1,vector<int>(n+1,0));
for(int i=1;i<=m;i++){
for(int j=1;j<=n;j++){
if(word1[i-1]==word2[j-1]){
dp[i][j]=1+dp[i-1][j-1];
}else{
dp[i][j]=max(dp[i-1][j],dp[i][j-1]);
}
}
}
return m-dp[m][n]+n-dp[m][n];
}
};