Edit Distance

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:

Insert a character

Delete a character

Replace a character

Example

Given word1 = "mart" and word2 = "karma", return 3.

Solution

state: f[i][j]a的前i个字符最少要用几次编辑可以变成b的前j个字符function: f[i][j] = MIN(f[i-1][j]+1, f[i][j-1]+1, f[i-1][j-1]) // a[i] == b[j]

= MIN(f[i-1][j]+1, f[i][j-1]+1, f[i-1][j-1]+1) // a[i] != b[j] initialize: f[i][0] = i, f[0][j] = j

answer: f[a.length()][b.length()]

class Solution: 
    # @param word1 & word2: Two string.
    # @return: The minimum number of steps.
    def minDistance(self, word1, word2):
        # write your code here
        m = len(word1)
        n = len(word2)

        f = [[0 for x in range(n + 1)] for y in range(m + 1)]

        f[0][0] = 0 

        for i in range(1, m + 1):
            f[i][0] = i
        for i in range(1, n + 1):
            f[0][i] = i

        for i in range(1, m + 1):
            for j in range(1, n + 1):
                if word1[i - 1] == word2[j - 1]:
                    f[i][j] = f[i - 1][j - 1]
                else:
                    f[i][j] = min(f[i - 1][j], f[i][j - 1], f[i - 1][j - 1]) + 1
        return f[m][n]

Last updated

Was this helpful?