Cerința
De-a lungul bulevardului sunt n
arbori, numerotați de la 1
la n
, pentru fiecare cunoscându-se înălțimea, exprimată în centimetri. Primarul dorește ca înălțimile arborilor să fie în ordine descrescătoare, și pentru aceasta apelează la vrăjitorul angajat al primăriei, care, pentru un anumit arbore poate să facă o vrajă astfel încât arborele să crească cu h
centimetri. Determinați numărul minim de vrăji necesare ca înălțimile arborilor să fie în ordine descrescătoare.
Date de intrare
Programul citește de la tastatură numerele n h
, iar apoi n
numere naturale, reprezentând înălțimile arborilor.
Date de ieșire
Programul va afișa pe ecran numărul C
, reprezentând numărul de vrăji necesare.
Restricții și precizări
1 ≤ n ≤ 1000
1 ≤ h ≤ 1000
- înălțimile arborilor sunt numere naturale nenule mai mici decât
1.000.000
Exemplu
Intrare
4 2 2 3 3 4
Ieșire
4
Explicație
Pentru primul arbore trebuie două vrăji, iar pentru al doilea și al treilea trebuie câte o vrajă.
Cum e corect?
cout < "As la info";
cout << "As la info";
cout >> "As la info";
Felicitări! Poți mai mult?
Avem sute de probleme pentru tine, fiecare cu explicații ușor de înțeles.
Greșit, dar nu-i bai!
Antrenează-te cu sutele de probleme pe care ți le-am pregătit. Îți explicăm fiecare problemă în parte.
Rezolvare
Iată rezolvarea de 100 de puncte pentru problema Vraja:
#include <iostream>
using namespace std;
int v[1005], n, h;
int main(){
cin >> n >> h;
for(int i = 1 ; i <= n ; ++i)
cin >> v[i];
int cnt = 0;
for(int i = n - 1 ; i > 0 ; i --)
if(v[i] < v[i+1])
{
int dif = v[i+1] - v[i];
int nrv = dif / h;
if(nrv * h < dif)
nrv ++;
cnt += nrv;
v[i] += nrv * h;
}
cout << cnt;
return 0;
}
Atenție
Enunțurile afișate pe această pagină aparțin exclusiv site-ului PbInfo. Astfel, pentru ștergerea conținutului, puteți să ne contactați la adresa .
Rezolvarea problemei #603 Vraja
Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #603 Vraja de pe PbInfo.ro. Atenție: nu încurajăm copiatul codului! Totuși, credem cu tărie că analizarea unei soluții corecte este o metodă foarte ușoară de a învăța informatică, astfel că oferim sursele pentru peste 1500 de probleme de pe platforma PbInfo.ro.
Pentru rezolvări PbInfo de la peste 1500 de probleme, vă invităm să intrați pe site-ul nostru!