2245 - Plata 1: Difference between revisions

From Bitnami MediaWiki
Mraa (talk | contribs)
Pagină nouă: ==Cerința== Se consideră n tipuri de bancnote, cu valorile v[1] v[2] ... v[n], ordonate strict crescător. Pentru fiecare tip de bancnote se știe numărul de bancnote disponibile c[1] c[2] ... c[n]. Se cere să se determine o modalitate de a plăti integral o sumă dată S cu bancnotele disponibile. ==Date de intrare== Programul citește de la tastatură numerele n și S, apoi valorile v[1] v[2] ... v[n] ale bancnotelor și apoi c[1] c[2] ... c[n]. ==Date de ieșire== Pr...
 
Mraa (talk | contribs)
No edit summary
 
Line 27: Line 27:
Se folosesc cinci bancnote de 1 leu, două de 10 lei, cinci de 50 de lei și una de 100 de lei: 5 * 1 + 2 * 10 + 5 * 50 + 1 * 100 = 375.
Se folosesc cinci bancnote de 1 leu, două de 10 lei, cinci de 50 de lei și una de 100 de lei: 5 * 1 + 2 * 10 + 5 * 50 + 1 * 100 = 375.
==Rezolvare==
==Rezolvare==
<syntaxhighlight lang="python3" line="1">
def plata_bancnote(n, S, valori, cantitati):
def plata_bancnote(n, S, valori, cantitati):
    rezultat = [0] * n
    suma_actuala = 0


    for i in range(n - 1, -1, -1):
  rezultat = [0] * n
        while suma_actuala + valori[i] <= S and cantitati[i] > 0:
  suma_actuala = 0
            suma_actuala += valori[i]
  for i in range(n - 1, -1, -1):
            cantitati[i] -= 1
      while suma_actuala + valori[i] <= S and cantitati[i] > 0:
            rezultat[i] += 1
          suma_actuala += valori[i]
 
          cantitati[i] -= 1
    return rezultat
          rezultat[i] += 1
  return rezultat




if __name__ == "__main__":
if __name__ == "__main__":
    # Citim datele de intrare
    n, S = map(int, input().split())
    valori = list(map(int, input().split()))
    cantitati = list(map(int, input().split()))


    # Apelăm funcția pentru a obține rezultatul
  # Citim datele de intrare
    rezultat = plata_bancnote(n, S, valori, cantitati)
  n, S = map(int, input().split())
  valori = list(map(int, input().split()))
  cantitati = list(map(int, input().split()))
  # Apelăm funcția pentru a obține rezultatul
  rezultat = plata_bancnote(n, S, valori, cantitati)
  # Afișăm rezultatul
  print(*rezultat)


    # Afișăm rezultatul
    print(*rezultat)
python plata_bancnote.py
python plata_bancnote.py
</syntaxhighlight>

Latest revision as of 18:05, 11 January 2024

Cerința[edit | edit source]

Se consideră n tipuri de bancnote, cu valorile v[1] v[2] ... v[n], ordonate strict crescător. Pentru fiecare tip de bancnote se știe numărul de bancnote disponibile c[1] c[2] ... c[n]. Se cere să se determine o modalitate de a plăti integral o sumă dată S cu bancnotele disponibile.

Date de intrare[edit | edit source]

Programul citește de la tastatură numerele n și S, apoi valorile v[1] v[2] ... v[n] ale bancnotelor și apoi c[1] c[2] ... c[n].

Date de ieșire[edit | edit source]

Programul va afișa pe ecran n numere, reprezentând o modalitate de plată a sumei S. Fiecare număr x[i] va reprezenta numărul de bancnote de valoarea x[i] folosite pentru plata sumei S.

Restricții și precizări[edit | edit source]

1 ≤ n ≤ 6 1 ≤ S ≤ 1000 1 ≤ v[i] ≤ 100 1 ≤ c[i] ≤ 10 oricare variantă corectă de plată a sumei S va fi luată în considerare pentru toate seturile de date există soluție ==Exemplu==: Intrare

5 375 1 5 10 50 100 6 3 4 6 1 Ieșire

5 0 2 5 1

Explicație[edit | edit source]

Se folosesc cinci bancnote de 1 leu, două de 10 lei, cinci de 50 de lei și una de 100 de lei: 5 * 1 + 2 * 10 + 5 * 50 + 1 * 100 = 375.

Rezolvare[edit | edit source]

<syntaxhighlight lang="python3" line="1"> def plata_bancnote(n, S, valori, cantitati):

  rezultat = [0] * n
  suma_actuala = 0
  for i in range(n - 1, -1, -1):
      while suma_actuala + valori[i] <= S and cantitati[i] > 0:
          suma_actuala += valori[i]
          cantitati[i] -= 1
          rezultat[i] += 1
  return rezultat


if __name__ == "__main__":

  # Citim datele de intrare
  n, S = map(int, input().split())
  valori = list(map(int, input().split()))
  cantitati = list(map(int, input().split()))
  # Apelăm funcția pentru a obține rezultatul
  rezultat = plata_bancnote(n, S, valori, cantitati)
  # Afișăm rezultatul
  print(*rezultat)

python plata_bancnote.py </syntaxhighlight>