Informatică, întrebare adresată de m1234, 8 ani în urmă

Clasa din care faceţi parte merge în excursie! Principalul obiectiv este Lacul Roşu, o locaţie deosebit de frumoasă. Pentru a vă bucura cât mai mult de peisaj toţi elevii se vor plimba cu barca pe lac. Bărcile sunt de maxim două persoane şi au restricţiile următoare:

greutatea totală suportată de o barcă este C;
dacă în barcă se aşază două persoane, atunci diferența în modul dintre greutățile acestora trebuie să fie maxim B, în caz contrar barca nu este balansată și riscă să se răstoarne.
Dacă o singură persoană se aşază în barcă, nu se aplică restricția a doua.

Cerința
Care este numărul minim de bărci necesare pentru a putea plimba toţi elevii în condiţii de siguranţă?

Date de intrare
Fișierul de intrare barci.in conţine pe prima linie trei numere naturale separate prin spaţiu: N, C și B, reprezentând numărul de elevi, capacitatea maximă a unei bărci şi respectiv diferenţa maximă dintre greutatea a două persoane care se pot aşeza în aceeaşi barcă. Pe a doua linie se află N numere naturale separate prin spaţiu w[i] (1 ≤ i ≤ N), reprezentând greutăţile celor N elevi.

Date de ieșire
Fișierul de ieșire barci.out va conţine o singură linie pe care va fi scris numărul minim de bărci necesare.

Restricții și precizări
1 ≤ N ≤ 100 000
1 ≤ w[i] ≤ C ≤ 1 000 000 000, pentru 1 ≤ i ≤ N
0 ≤ B ≤ 1 000 000 000
Pentru teste în valoare de 30 de puncte, N ≤ 10
Pentru teste în valoare de 60 de puncte, N ≤ 1000

Problema #2186 de pe pbinfo

Răspunsuri la întrebare

Răspuns de ap53
3
Am atasat fisierul sursa C++
Anexe:
Alte întrebări interesante