Rezolvare completă PbInfo #603 Vraja

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 Adresa de email.

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!