| 시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
|---|---|---|---|---|---|
| 1 초 | 1024 MB | 19 | 18 | 14 | 93.333% |
Bitlandijos prekybos tinklas „Baxima“ nori modernizuoti savo parduotuves ir įrengti išmanius kasos aparatus. Vienas iš išmaniosios kasos komponentų yra robotas, gebantis automatiškai grąžinti grąžą bitais (Bitlandijos valiuta).
Bitų banknotai turi šiuos nominalus: $1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024$.
Dienos pradžioje kasa yra tuščia. Toliau yra registruojamos visos transakcijos: į kasą įdedamų banknotų nominalai. Trūksta tik programinės įrangos, kuri suskaičiuotų, kaip geriausia parinkti grąžą kiekvienam klientui.
Parašykite progamą, kuri rastų, kokiais nominalais robotas turi duoti grąžą, kad kiekvienam klientui būtų atiduodama kuo mažiau banknotų.
Pirmoje eilutėje įrašytas transakcijų skaičius $T$. Sekančiose $T$ eilučių įrašyta po vieną skaičių $t_i$:
Kiekvienai grąžos transakcijai ($t_i < 0$), jūs turite išvesti po eilutę, kurioje būtų įrašyti grąžai panaudoti banknotai, nuo didžiausio iki mažiausio. Nepamirškite, jog robotas turi grąžinti pinigus taip, kad banknotų skaičius būtų kuo mažesnis.
Laikykite, kad kasoje visuomet bus pakankamai banknotų, kad pavyktų duoti grąžą klientui.
10 8 8 16 4 4 -20 4 -16 1 -5
16 4 8 8 4 1
Pirma į kasą įdedami banknotai $8, 8, 16, 4, 4$. Pirmajam klientui duoti $20$ bitų grąžą geriausia $16+4$ (o ne, pavyzdžiui, $8+8+4$).
Tuomet į kasą dar įdedamas $4$ bitų banknotas. Tai reiškia, kad iš viso kasoje yra likę $8, 8, 4, 4$. Antrajam klientui duoti $16$ bitų grąžą geriausia $8+8$.
Galiausiai į kasą įdedamas dar $1$ bito banknotas. Kasoje yra likę banknotai $4, 4, 1$. Paskutiniajam klientui duoti 5 bitų grąžą tegalima $4+1$.