#include <iostream> using namespace std; const int stala=5e4+10; int dp[stala][2][2]; int tab[stala]; int main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int ile; cin>>ile; for(int i=1;i<=ile;i++){ cin>>tab[i]; } dp[1][1][0]=1; dp[1][1][1]=1; for(int i=2;i<=ile;i++){ for(int j=0;j<=1;j++){ for(int z=0;z<=1;z++){ if(j==1){ dp[i][j][z]=min(dp[i-1][0][1-z],dp[i-1][1][1-z])+1; } else{ if(z==0){ if(tab[i-1]>tab[i]){ dp[i][j][z]=min(dp[i-1][0][1-z],dp[i-1][1][1-z]); } else{ dp[i][j][z]=dp[i-1][1][1-z]; } } else{ if(tab[i-1]<tab[i]){ dp[i][j][z]=min(dp[i-1][0][1-z],dp[i-1][1][1-z]); } else{ dp[i][j][z]=dp[i-1][1][1-z]; } } } } } } cout<<min(min(dp[ile][0][0],dp[ile][0][1]),min(dp[ile][1][0],dp[ile][1][1])); 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 | #include <iostream> using namespace std; const int stala=5e4+10; int dp[stala][2][2]; int tab[stala]; int main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int ile; cin>>ile; for(int i=1;i<=ile;i++){ cin>>tab[i]; } dp[1][1][0]=1; dp[1][1][1]=1; for(int i=2;i<=ile;i++){ for(int j=0;j<=1;j++){ for(int z=0;z<=1;z++){ if(j==1){ dp[i][j][z]=min(dp[i-1][0][1-z],dp[i-1][1][1-z])+1; } else{ if(z==0){ if(tab[i-1]>tab[i]){ dp[i][j][z]=min(dp[i-1][0][1-z],dp[i-1][1][1-z]); } else{ dp[i][j][z]=dp[i-1][1][1-z]; } } else{ if(tab[i-1]<tab[i]){ dp[i][j][z]=min(dp[i-1][0][1-z],dp[i-1][1][1-z]); } else{ dp[i][j][z]=dp[i-1][1][1-z]; } } } } } } cout<<min(min(dp[ile][0][0],dp[ile][0][1]),min(dp[ile][1][0],dp[ile][1][1])); return 0; } |