#include "bits/stdc++.h" using namespace std; #define REP(i, n) for(int i=0; i<(n); i++) #define RREP(i, n) for(int i=(n-1); i>=0; i--) int N,M; string S, T; int cost(string s, string t) { int ret = 0; REP(i,s.size()) ret += (s[i] != t[i]); return ret + abs((int)(s.size() - t.size())); } signed main() { cin >> N >> M >> S >> T; map > dp; dp[""][""] = 0; RREP(i,N) { string s = S.substr(i); string s1 = (s.size() > 1 ? s.substr(1) : ""); RREP(j,M) { string t = T.substr(j); string t1 = (t.size() > 1 ? t.substr(1) : ""); dp[s][t] = min(dp[s1][t1] + (s[0] != t[1]), dp[s1][t] + 1); } } cout << dp[S][T] << endl; return 0; }