動態規劃---最短編輯距離
阿新 • • 發佈:2019-01-30
描述:
設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;
三、程式碼:
- #include<stdio.h>
- #include<string.h>
- #include<algorithm>
- usingnamespace std;
-
#define N 10
- int dp[N][N];//dp[i][j]表示a的前i個和b的前j個相同後的最短距離
- int main()
- {
- char a[N];
- char b[N];
- freopen("dInput.txt","r",stdin);
- freopen("doutput.txt","w",stdout);
- scanf("%s%s",a,b);
- int la=strlen(a);
- int lb=strlen(b);
- for(int i=1;i<=la;i++)
- dp[i][0]=i;
-
for
- dp[0][j]=j;
- for(int i=1;i<=la;i++)
- {
- for(int j=1;j<=lb;j++)
- {
- int insert=dp[i][j-1]+1;
- int deletes=dp[i-1][j]+1;
- int replace;
- if(a[i-1]==b[j-1])
- replace=dp[i-1][j-1];
- else
- replace=dp[i-1][j-1]+1;
- dp[i][j]=min(min(insert,deletes),replace);
- }
- }
- printf("%d\n",dp[la][lb]);
- return 0;
- }