#include <cstdio>
#include <algorithm>
#define scanf(...) scanf(__VA_ARGS__)?:0
using namespace std;
int n, a[50005];
int main() {
scanf("%d", &n);
for (int i=1; i<=n; i++) scanf("%d", &a[i]);
// pierwszy mały
int zm=1, po=0;
for (int i=2; i<=n; i++) {
int npo, nzm = min(zm, po) + 1;
if (i % 2 == 0) {
if (a[i] > a[i-1]) npo = min(zm, po);
else npo = zm;
} else {
if (a[i] < a[i-1]) npo = min(zm, po);
else npo = zm;
}
zm = nzm;
po = npo;
}
int wynik = min(zm, po);
// pierwszy duzy
zm = 1; po = 0;
for (int i=2; i<=n; i++) {
int npo, nzm = min(zm, po) + 1;
if (i % 2 == 1) {
if (a[i] > a[i-1]) npo = min(zm, po);
else npo = zm;
} else {
if (a[i] < a[i-1]) npo = min(zm, po);
else npo = zm;
}
zm = nzm;
po = npo;
}
int wynik2 = min(zm, po);
printf("%d", min(wynik, wynik2));
}
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 | #include <cstdio> #include <algorithm> #define scanf(...) scanf(__VA_ARGS__)?:0 using namespace std; int n, a[50005]; int main() { scanf("%d", &n); for (int i=1; i<=n; i++) scanf("%d", &a[i]); // pierwszy mały int zm=1, po=0; for (int i=2; i<=n; i++) { int npo, nzm = min(zm, po) + 1; if (i % 2 == 0) { if (a[i] > a[i-1]) npo = min(zm, po); else npo = zm; } else { if (a[i] < a[i-1]) npo = min(zm, po); else npo = zm; } zm = nzm; po = npo; } int wynik = min(zm, po); // pierwszy duzy zm = 1; po = 0; for (int i=2; i<=n; i++) { int npo, nzm = min(zm, po) + 1; if (i % 2 == 1) { if (a[i] > a[i-1]) npo = min(zm, po); else npo = zm; } else { if (a[i] < a[i-1]) npo = min(zm, po); else npo = zm; } zm = nzm; po = npo; } int wynik2 = min(zm, po); printf("%d", min(wynik, wynik2)); } |
English