#include<bits/stdc++.h>
using namespace std;
const int maxn=1001;
int dp[maxn][maxn];
int a[maxn];
int b[maxn];
int main()
{
int n,m;
cin>>n>>m;
for(int i=1; i<=n; i++)
cin>>a[i];
for(int i=1; i<=m; i++)
cin>>b[i];
for(int i=1; i<=n; i++)
{
int mx=0;
for(int j=1; j<=m; j++)
{
dp[i][j]=dp[i-1][j];
if(a[i]>b[j]&&mx<dp[i-1][j])
mx=dp[i-1][j];
else if(a[i]==b[j])
dp[i][j]=mx+1;
}
}
int ans=0;
for(int i=1; i<=m; i++)
ans=max(ans,dp[n][i]);
cout<<ans<<endl;
return 0;
}