动态规划---最短编辑距离
描述:
設A和B是2個字符串。要用最少的字符操作將字符串A轉換為字符串B。這里所說的字符操作包括:
(1)刪除一個字符;
(2)插入一個字符;
(3)將一個字符改為另一個字符。
將字符串A變換為字符串B所用的最少字符操作數稱為字符串A到B的編輯距離,記為d(A,B)。試設計一個有效算法,對任給的2個字符串A和B,計算出它們的編輯距離d(A,B)。
要求:
輸入:第1行是字符串A,第2行是字符串B。
輸出:字符串A和B的編輯距離d(A,B)
思路:
開一個二維數組d[i][j]來記錄a0-ai與b0-bj之間的編輯距離,要遞推時,需要考慮對其中一個字符串的刪除操作、插入操作和替換操作分別花費的開銷,從中找出一個最小的開銷即為所求
具體算法:
首先給定第一行和第一列,然后,每個值d[i,j]這樣計算:d[i][j] = min(d[i-1][j]+1, d[i][j-1]+1, d[i-1][j-1]+(s1[i]==s2[j]?0:1));
?最后一行,最后一列的那個值就是最小編輯距離
二、算法分析
dp[i][j]表示a的前i個和b的前j個相同后的最短距離
dp[i][j]來自于三種狀態{
??? 1、刪除,dp[i-1][j]+1;
??? 2、插入,dp[i][j-1]+1;
??? 3、替換,if(a[i]==b[j]) dp[i][j]=dp[i-1][j-1],else dp[i][j]=dp[i-1][j-1]+1;
三、代碼:
[cpp]?view plaincopy總結
以上是生活随笔為你收集整理的动态规划---最短编辑距离的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 说说尾递归
- 下一篇: Levenshtein distance