#include <bits/stdc++.h>
using namespace std;
int main() {
ios_base::sync_with_stdio(0); cin.tie(0);
int n;
cin >> n;
vector<int> v;
int num;
for(int i=0;i<n;i++){
cin >> num;
v.push_back(num);
}
vector<int> v2 = v;
vector<int> v3 = v;
bool rosnie=true;
bool maleje=true;
int ans2=0;
int ans1=0;
for(int i=0;i<n;i++){
if(rosnie){
if(v2[i] >= v2[i+1]){
v2[i+1]=INT_MAX;
ans1++;
}
rosnie=false;
}
else{
if(v2[i] <= v2[i+1]){
v2[i+1]=INT_MIN;
ans1++;
}
rosnie=true;
}
if(maleje){
if(v3[i] <= v3[i+1]){
v3[i+1]=INT_MIN;
ans2++;
}
maleje=false;
}
else{
if(v3[i] >= v3[i+1]){
v3[i+1]=INT_MAX;
ans2++;
}
maleje=true;
}
}
cout << min(ans1, ans2);
return 0;
}
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 | #include <bits/stdc++.h> using namespace std; int main() { ios_base::sync_with_stdio(0); cin.tie(0); int n; cin >> n; vector<int> v; int num; for(int i=0;i<n;i++){ cin >> num; v.push_back(num); } vector<int> v2 = v; vector<int> v3 = v; bool rosnie=true; bool maleje=true; int ans2=0; int ans1=0; for(int i=0;i<n;i++){ if(rosnie){ if(v2[i] >= v2[i+1]){ v2[i+1]=INT_MAX; ans1++; } rosnie=false; } else{ if(v2[i] <= v2[i+1]){ v2[i+1]=INT_MIN; ans1++; } rosnie=true; } if(maleje){ if(v3[i] <= v3[i+1]){ v3[i+1]=INT_MIN; ans2++; } maleje=false; } else{ if(v3[i] >= v3[i+1]){ v3[i+1]=INT_MAX; ans2++; } maleje=true; } } cout << min(ans1, ans2); return 0; } |
English