#include<bits/stdc++.h>
using namespace std;
const int N=4e5+1;
int a[N],b[N],l,r;
int mas[N],vis[N];
inline bool dfs(int x){
int L=max(a[x],l),R=min(b[x],r);
for(int v=L;v<=R;++v){
if(vis[v]){
continue;
}
vis[v]=1;
if(!mas[v]||dfs(mas[v])){
mas[v]=x;
return true;
}
}
return false;
}
int main(){
int n,q;
scanf("%d%d",&n,&q);
for(int i=1;i<=n;++i){
scanf("%d",&a[i]);
}
for(int i=1;i<=n;++i){
scanf("%d",&b[i]);
}
while(q--){
int ans=0;
scanf("%d%d",&l,&r);
memset(vis,0,sizeof(vis)),memset(mas,0,sizeof(mas));
for(int i=1;i<=n;++i){
if(dfs(i)){
++ans;
}
}
printf("%d\n",ans);
}
return 0;
}
打的二分图匹配,不知道哪里错了qwq