IQOverload

CF 256C

Aug 17th, 2014
286
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.41 KB | None | 0 0
  1. #include <algorithm>
  2. #include <bitset>
  3. #include <deque>
  4. #include <cmath>
  5. #include <cstdio>
  6. #include <cstdlib>
  7. #include <cstring>
  8. #include <iostream>
  9. #include <list>
  10. #include <map>
  11. #include <queue>
  12. #include <set>
  13. #include <sstream>
  14. #include <stack>
  15. #include <string>
  16. #include <utility>
  17. #include <vector>
  18.  
  19. #define fst first
  20. #define snd second
  21. #define all(x) (x).begin(), (x).end()
  22. #define clr( a , v ) memset( a , v , sizeof(a) )
  23. #define pb push_back
  24. #define mp make_pair
  25. #define sz size()
  26. #define FORN( i , s , n ) for( int i = s ; i < (int)(n) ; i++ )
  27. #define FOR( i , n ) FORN( i , 0 , n )
  28. #define FORIT(i,x) for( typeof x.begin() i = x.begin() ; i != x.end() ; i++ )
  29. #define trace(x)    cerr << #x << ": " << x << endl;
  30. #define trace2(x, y) cerr << #x << ": " << x << " | " << #y << ": " << y << endl;
  31. #define read ios::sync_with_stdio(false)
  32.  
  33. using namespace std;
  34.  
  35. typedef long long int64;
  36. typedef vector <int> vi;
  37. typedef pair <int,int> ii;
  38. typedef vector <string> vs;
  39. typedef vector <ii> vii;
  40.  
  41. int a[5001];
  42.  
  43. int f( int L , int R , int h ){
  44.     if( L > R ) return 0;
  45.     int id, min_h = 1e9+1;
  46.     for( int i = L ; i <= R ; i++ ){
  47.         if( a[i] - h < min_h ){
  48.             min_h = a[i] - h, id = i;
  49.         }
  50.     }
  51.     return min( R - L + 1 , min_h + f( L , id-1 , h + min_h ) + f( id+1 , R , h + min_h ) );
  52. }
  53.  
  54. int main(){
  55.     int n; cin >> n;
  56.     FOR( i , n ) cin >> a[i];
  57.     cout << f( 0 , n-1 , 0 ) << endl;
  58.     return 0;
  59. }
Advertisement
Add Comment
Please, Sign In to add comment