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>
using namespace std;
typedef long long ll;
//#include<bits/extc++.h>
//__gnu_pbds
vector<int> a;
int check(int l,int r,int k){
int prev = l;
if(l==r) return 0;
int ans = 0;
for(int i=l+1;i<r;i++){
if(a[i]!=a[i-1]){
if(a[prev]==k){
if((i-prev)%2) return -1;
ans+=(i-prev)/2;
}
prev = i;
}
}
if(a[prev]==k){
if((r-prev)%2) return -1;
ans+=(r-prev)/2;
}
return ans;
}
int main(){
ios_base::sync_with_stdio(0),cin.tie(0),cout.tie(0);
int n;
cin>>n;
a.resize(n);
for(int i=0;i<n;i++) cin>>a[i];
int minn = 1e9;
for(int i=0;i<=n;i++){
int a = check(0,i,1);
int b = check(i,n,-1);
if(a!=-1 && b!=-1) minn = min(minn,a+b);
}
if(minn>n) cout<<-1<<"\n";
else cout<<minn<<"\n";
return 0;
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |