Given two words word1 and word2, find the minimum number of steps required to convert word1 to word2. (each operation is counted as 1 step.)
You have the following 3 operations permitted on a word:
a) Insert a character b) Delete a character c) Replace a character
算法
O(n^2) DP https://segmentfault.com/a/1190000003741294
class Solution {
public:
int minDistance(
string word1,
string word2) {
if (word1.length() < word2.length())
swap(word1, word2);
vector<int> dp(word2.length() +
1);
for (
int i =
0; i < dp.size(); ++i)
dp[i] = i;
int upleft =
0;
for (
int i =
1; i <= word1.size(); ++i) {
upleft = dp[
0];
dp[
0] = i;
for (
int j =
1; j <= word2.size(); ++j) {
int rec = dp[j];
if (word1[i -
1] == word2[j -
1])
dp[j] = upleft;
else
dp[j] = min(upleft, min(dp[j], dp[j -
1])) +
1;
upleft = rec;
}
}
return dp[word2.length()];
}
};
转载请注明原文地址: https://ju.6miu.com/read-1298084.html