#include<bits/stdc++.h>
using namespace std;
int n, wynik1, wynik2, x, wynik3, wynik4;
int tab1[50007];
int tab2[50007];
int tab3[50007];
int tab4[50007];
int main()
{
std::ios_base::sync_with_stdio(false);
std::cin.tie(NULL);
cin >> n;
for(int i=1; i<=n; i++)
{
cin >> tab1[i];
tab2[i]=tab1[i];
tab3[i]=tab1[i];
tab4[i]=tab1[i];
}
tab1[0]=-100000000;
tab2[0]=100000000;
tab3[0]=-100000000;
tab4[0]=100000000;
if(n%2==0)
{
tab1[n+1]=100000000;
tab3[n+1]=100000000;
}
else
{
tab1[n+1]=-100000000;
tab3[n+1]=-100000000;
}
if(n%2==0)
{
tab2[n+1]=-100000000;
tab4[n+1]=-100000000;
}
else
{
tab2[n+1]=100000000;
tab4[n+1]=100000000;
}
for(int i=2; i<=n; i+=2)
{
if(tab1[i]>=tab1[i+1] or tab1[i]>=tab1[i-1])
{
tab1[i]=min(tab1[i+1]-1, tab1[i-1]-1);
wynik1++;
}
}
for(int i=1; i<=n; i+=2)
{
if(tab3[i]<=tab3[i+1] or tab3[i]<=tab3[i-1])
{
tab3[i]=max(tab3[i+1]+1, tab3[i-1]+1);
wynik3++;
}
}
for(int i=2; i<=n; i+=2)
{
if(tab2[i]<=tab2[i+1] or tab2[i]<=tab2[i-1])
{
tab2[i]=max(tab2[i+1]+1, tab2[i-1]+1);
wynik2++;
}
}
for(int i=1; i<=n; i+=2)
{
if(tab4[i]>=tab4[i+1] or tab4[i]>=tab4[i-1])
{
tab4[i]=min(tab4[i+1]-1, tab4[i-1]-1);
wynik4++;
}
}
cout << min(wynik4,min(min(wynik1, wynik2),wynik3));
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 | #include<bits/stdc++.h> using namespace std; int n, wynik1, wynik2, x, wynik3, wynik4; int tab1[50007]; int tab2[50007]; int tab3[50007]; int tab4[50007]; int main() { std::ios_base::sync_with_stdio(false); std::cin.tie(NULL); cin >> n; for(int i=1; i<=n; i++) { cin >> tab1[i]; tab2[i]=tab1[i]; tab3[i]=tab1[i]; tab4[i]=tab1[i]; } tab1[0]=-100000000; tab2[0]=100000000; tab3[0]=-100000000; tab4[0]=100000000; if(n%2==0) { tab1[n+1]=100000000; tab3[n+1]=100000000; } else { tab1[n+1]=-100000000; tab3[n+1]=-100000000; } if(n%2==0) { tab2[n+1]=-100000000; tab4[n+1]=-100000000; } else { tab2[n+1]=100000000; tab4[n+1]=100000000; } for(int i=2; i<=n; i+=2) { if(tab1[i]>=tab1[i+1] or tab1[i]>=tab1[i-1]) { tab1[i]=min(tab1[i+1]-1, tab1[i-1]-1); wynik1++; } } for(int i=1; i<=n; i+=2) { if(tab3[i]<=tab3[i+1] or tab3[i]<=tab3[i-1]) { tab3[i]=max(tab3[i+1]+1, tab3[i-1]+1); wynik3++; } } for(int i=2; i<=n; i+=2) { if(tab2[i]<=tab2[i+1] or tab2[i]<=tab2[i-1]) { tab2[i]=max(tab2[i+1]+1, tab2[i-1]+1); wynik2++; } } for(int i=1; i<=n; i+=2) { if(tab4[i]>=tab4[i+1] or tab4[i]>=tab4[i-1]) { tab4[i]=min(tab4[i+1]-1, tab4[i-1]-1); wynik4++; } } cout << min(wynik4,min(min(wynik1, wynik2),wynik3)); } |
English