P9572 「NnOI R2-T4」Colorful Days♪
题目链接
定义
不难发现,
然后我们用
此时
附代码:
#include<bits/stdc++.h>
using namespace std;
const int N(1e6+5);
int read(){
int x=0,f=1;char ch=getchar();
for(;!isdigit(ch);ch=getchar())if(ch=='-')f=-1;
for(;isdigit(ch);ch=getchar())x=(x<<1)+(x<<3)+(ch^48);
return x*f;
}
void write(int x){
if(x<0)putchar('-'),x=-x;
if(x>9)write(x/10);
putchar(x%10+48);
}int s[N],t[N];
vector<int> v[N],z,b;bool pot[N];
int main(){
z.push_back(1);
int n=read(),m=read(),c1=read(),c2=read();int cnt=0;
for(int i=1;i<=n;++i)s[i]=read(),pot[s[i]]=1,v[s[i]].push_back(i);
for(int i=1;i<=m;++i){
t[i]=read();
if(pot[t[i]])z.push_back(t[i]),cnt++;
}int pre=0,ans=1;
for(int i=1;i<=cnt;++i){
int k=upper_bound(v[z[i]].begin(),v[z[i]].end(),pre)-v[z[i]].begin();
if(k==v[z[i]].size()) ++ans,pre=v[z[i]][0];
else pre=v[z[i]][k];
}
cout<<cnt*c1<<' '<<ans*c2<<'\n';
return 0;
}