不懂就问
查看原帖
不懂就问
307940
aaaaaaaawsl楼主2021/7/17 15:25
#include<iostream>
#include<cstdio>
using namespace std;
int a[100001],b[100001],map[100001],f[100001];
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){scanf("%d",&a[i]);map[a[i]]=i;}
	for(int i=1;i<=n;i++){scanf("%d",&b[i]);f[i]=0x7fffffff;}
	int len=0;
	f[0]=0;
	for(int i=1;i<=n;i++)
	{
		int l=0,r=len,mid;
		if(map[b[i]]>f[len])f[++len]=map[b[i]];
		else 
		{
		while(l<r)
		{	
		    mid=(l+r)/2;
		    if(f[mid]>map[b[i]])r=mid;
			else l=mid+1; 
		}
		f[l]=min(map[b[i]],f[l]);
     	}
    }
    cout<<len;
    return 0
}

看不懂第三个for循环,题解第一篇,主要是len,map,f的作用,求dl解答(我好菜啊


PS:其实题解区哪位dl没解释,我l,r也不懂


PPS:当然可能是我眼瞎,dbq

2021/7/17 15:25
加载中...