算法板子

#include<bits/stdc++.h>
using namespace std;
int n, m;
const int N = 1010;
string s1, s2;
int dp[N][N];
int main() {
    cin >> n >> s1;
    cin >> m >> s2;
    memset(dp, 0x3f, sizeof dp);
    dp[0][0] = 0;
    for (int i = 1; i <= n; ++i) {
        dp[i][0] = i;
    }
    for (int i = 1; i <= m; ++i) {
        dp[0][i] = i;
    }
    for (int i = 1; i <= n; ++i) {
        for (int j = 1; j <= m; ++j) {
            if (s1[i - 1] == s2[j - 1]) {
                dp[i][j] = min(dp[i][j], dp[i - 1][j - 1]);
            }
            dp[i][j] = min(dp[i][j], dp[i - 1][j - 1] + 1);
            dp[i][j] = min(dp[i][j], dp[i - 1][j] + 1);
            dp[i][j] = min(dp[i][j], dp[i][j - 1] + 1);
        }
    }
    cout << dp[n][m] << endl;
    return 0;
}
本文为原创文章,欢迎分享,勿全文转载,如果内容你实在喜欢,可以加入收藏夹,说不定哪天故事又继续更新了呢。
本文地址:https://qoogle.top/%e6%9c%80%e7%9f%ad%e7%bc%96%e8%be%91%e8%b7%9d%e7%a6%bb-%e7%ae%97%e6%b3%95%e6%9d%bf%e5%ad%90/
最后修改日期:2020年6月18日

作者

留言

撰写回覆或留言

发布留言必须填写的电子邮件地址不会公开。