#include #define syosu(x) fixed< P; typedef pair pdd; typedef pair pll; typedef vector vi; typedef vector vvi; typedef vector vd; typedef vector vvd; typedef vector vl; typedef vector vvl; typedef vector vs; typedef vector

vp; typedef vector vvp; typedef vector vpll; typedef pair pip; typedef vector vip; const int inf=1<<30; const ll INF=1ll<<60; const double pi=acos(-1); const double eps=1e-8; const ull mod=1e9+7; const int dx[4]={-1,0,1,0},dy[4]={0,-1,0,1}; int n,m; string s,t; vvi dp; int main(){ cin>>n>>m>>s>>t; dp=vvi(n+1,vi(m+1)); for(int i=0;i<=n;i++) for(int j=0;j<=m;j++) if(i||j){ if(i&&!j) dp[i][j]=i; else if(!i&&j) dp[i][j]=j; else{ if(s[i]==t[j]) dp[i][j]=dp[i-1][j-1]; else dp[i][j]=min({dp[i-1][j],dp[i][j-1],dp[i-1][j-1]})+1; } } cout<