#include"bits/stdc++.h" //#include<bits/stdc++.h> using namespace std; #define print(x) cout<<x<<endl; #define rep(i,a,b) for(int i=a;i<b;i++) #define REP(i,a) for(int i=0;i<a;i++) typedef long long ll; typedef pair<int, int> PI; typedef pair<int, PI> V; typedef vector<int> VE; const ll mod = 100000000000; int n, m; string s, t; int d[1002][1002]; int main() { cin >> n >> m; cin >> s; cin >> t; REP(i, n + 1)REP(j, m + 1)d[i][j] = mod; REP(i, 1002)d[i][0] = d[0][i] = i; int cost = 0; rep(i,1, n+1)rep(j,1, m+1) { if (s[i - 1] == t[j - 1])cost = 0; else cost = 1; d[i][j] = min(d[i - 1][j] + 1, min(d[i][j - 1] + 1, d[i - 1][j - 1] + cost)); } print(d[n][m]); return 0; }