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));

}