编辑距离

动态规划:
dp[i][j]表示word1的i位置到word2的位置j位置需要的最小步数,所以word1[i]==word2[i],dp[i][j]=dp[i-1][j-1];当不相等时,dp[i][j]=min(dp[i-1][j-1],dp[i-1][j],dp[i][j-1])+1,依次表示替换,删除,和插入操作。

def distance(word1,word2)->int:
	n1=len(word1)
	n2=len(word2)
	dp=[[0]*(n2+1) for _ in range(n1+1)]
	# 第一行
	for j in range(1,n2+1):
		dp[0][j]=j         # 初始化
	# 第一列
	for i in range(1,n1+1):
		dp[i][0]=i
	for i in range(1,n1+1):
		for j in range(1,n2+1):
			if word1[i-1]==word2[j-1]:
				dp[i][j]=dp[i-1][j-1]
			else:
				dp[i][j]=min(dp[i-1][j-1],dp[i-1][j],dp[i][j-1])
	return dp[-1][-1]

你可能感兴趣的:(剑指offer)