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