1.因为a和b两个数列没有相同的元素,所以必须让a的第一个元素的字典序小于b的第一个元素的字典序。
2.将b进行桶排序,然后从大到小进行取min,这样的话,就代表>=这个数的数出现最早的下标是多少。
3.i-1是a数组往前移动的步数,b[a[i]+1]-1是比a[i]大的数移动到最前面的最小步数
#include<bits/stdc++.h>
using namespace std;
const int N=2e5+10;
const int INF=0x3f3f3f3f;
int a[N],b[N];
void solve(){
int n;
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
for(int i=1;i<=n;i++){
int ver;
scanf("%d",&ver);
b[ver]=i;
}
for(int i=n-1;i>=1;i--) b[i*2]=min(b[i*2],b[(i+1)*2]);
int res=2*n;
for(int i=1;i<=n;i++) res=min(res,i-1+b[a[i]+1]-1);
printf("%d\n",res);
}
int main(){
int t;
scanf("%d",&t);
while(t--){
solve();
}
return 0 - 0;
}