This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#define int long long
#define mod 1000000007
#define endl '\n'
using namespace std;
signed main(){
ios_base::sync_with_stdio(0);cin.tie(0);cout.tie(0);
int n;
cin>>n;
pair<int,int>pr[n];
for(int i=0;i<n;i++){
cin>>pr[i].first;
}
for(int i=0;i<n;i++){
cin>>pr[i].second;
}
bool bl[n];
memset(bl,false,sizeof(bl));
for(int i=0;i<n;i++){
int a=0,b=0,z=-1;
for(int w=i;w<n&&pr[w].first<=pr[i].first;w++){
if(pr[w].second==pr[i].first)a++;
if(bl[w])b++;
if(a>=b){z=w;}
}
for(int w=i;w<=z;w++){
if(pr[w].second==pr[i].first)bl[w]=true;
else bl[w]=false;
}
a=0;b=0;z=n;
for(int w=i;w>=0&&pr[w].first<=pr[i].first;w--){
if(pr[w].second==pr[i].first)a++;
if(bl[w])b++;
if(a>=b){z=w;}
}
for(int w=i;w>=z;w--){
if(pr[w].second==pr[i].first)bl[w]=true;
else bl[w]=false;
}
}
int ans=0;
for(int i=0;i<n;i++)if(bl[i])ans++;
cout<<ans;
}
//5 1 1 1 6 5
//5 5 6 5 6
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |