buldo

Time limit: 0.1s Memory limit: 64MB Input: buldo.in Output: buldo.outPoints by default: 10p

Dorești să nivelezi terenul pe care l-ai cumpărat, care are lățimea de 11 metru și lungimea de NN metri, fiind alcătuit din NN zone succesive, fiecare zonă având lungimea de 11 metru. Terenul se reprezintă ca un șir de NN numere naturale h1,h2,h3,,hNh_1, h_2, h_3, \ldots, h_N reprezentând înălțimile în metri pe care le au zonele din terenul inițial, privite de la stânga spre dreapta.

Pentru a nivela terenul ai închiriat un buldozer care funcționează astfel. Se alege o înălțime HH (număr natural) la care ridicăm lama buldozerului. Inițial buldozerul are pe lamă o cantitate C=0C=0 metri cubi de pământ. Buldozerul începe să meargă de la stânga la dreapta și când ajunge la zona ii, în funcție de înălțimea hih_i a acesteia, se va afla în una dintre următoarele situații:

  • dacă hiHh_i \geq H atunci cantitatea suplimentară hiHh_i - H se adaugă la CC și nivelul zonei ajunge la HH.
  • dacă hi<Hh_i < H atunci se scade din CC diferența HhiH - h_i pentru a aduce nivelul zonei la nivelul HH.


Remarcăm faptul că HH trebuie ales inițial astfel încât de fiecare dată când buldozerul ajunge în a doua situație să aibă pe lamă suficient pământ (CHhiC \geq H - h_i). După ce buldozerul parcurge cele NN zone de lungime 11, pe lama buldozerului e posibil să mai rămână pământ, dar asta nu te interesează, pentru că la capătul din dreapta al terenului este un râu, și pământul rămas se va vărsa acolo.

Cerință

Scrieți un program care calculează înălțimea maximă HH la care poate fi ridicată lama, astfel încât terenul să poată fi nivelat la acea înălțime.

Date de intrare

Fișierul de intrare buldo.in conține pe prima linie numărul natural NN, iar pe a doua linie, separate prin câte un spațiu, cele NN numere naturale h1h_1, h2h_2, h3h_3, \dots, hNh_N, cu semnificația din enunț.

Date de ieșire

Fișierul de ieșire buldo.out va conține o singură linie, pe care va fi scris numărul natural HH cerut.

Restricții și precizări

  • 1N100 0001 \leq N \leq 100\ 000
  • Înălțimile sunt numere naturale, 1hi1 000 000 0001 \leq h_i \leq 1\ 000\ 000\ 000, pentru orice ii, 1iN1 \leq i \leq N.
  • Pentru teste în valoare de 50 de puncte, N1 000N \leq 1\ 000 și hi1 000h_i \leq 1\ 000, pentru orice ii, 1iN1 \leq i \leq N.

Exemplu

buldo.in

4
5 2 1 6

buldo.out

2

Explicație

Dacă se fixează lama la înălțimea H=2H=2, după ce se trece de zona 11 (primul metru pe lungime), această zonă rămâne la înălțimea 22 și C=3C=3 metri cubi de pământ sunt duși de lamă la zona 22. Acolo se vor obține în total 2+3=52+3=5 metri cubi de pământ, dar se păstrează doar 22, iar restul de C=3C=3 se transportă la zona 33. La zona 33 se vor obține în total 1+3=41+3=4 metri cubi de pământ, dar se păstrează doar 22, iar restul de C=2C=2 se transportă la zona 44. La zona 44 se vor obține în total 6+2=86+2=8 metri cubi de pământ, dar se păstrează doar 22, iar restul de C=6C=6 se aruncă în râu.

Dacă s-ar fixa lama la înălțimea H=3H=3, la zona 33 se poate ajunge doar la înălțimea 22 și încercarea eșuează (fiind o înălțime mai mică decât cea propusă).

Log in or sign up to be able to send submissions!