forked from projeto-de-algoritmos/Greed_Exercicios-Beecrowd
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBeecrowd_1021_Notas_e_Moedas.py
51 lines (45 loc) · 3.25 KB
/
Beecrowd_1021_Notas_e_Moedas.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# ========================================================================================================================
# Beecrowd - 1021 - Notas e Moedas - Nivel 6
# ========================================================================================================================
# Teoria: Algoritmos Ambiciosos
# Algoritmo utilizado: Algoritmo das moedas
# ========================================================================================================================
# Para facilitar a correçao, foram incluidos no codigo comentarios detalhados, mesmo se desnecessarios :)
# ========================================================================================================================
if __name__ == "__main__":
# ====================================================================================================================
# As notas consideradas são de 100, 50, 20, 10, 5, 2. As moedas possiveis são de 1, 0.50, 0.25, 0.10, 0.05 e 0.01.
# ====================================================================================================================
tipos_notas = [10000, 5000, 2000, 1000, 500, 200] # as notas foram multiplicadas por 100 para facilitar os calculos
tipos_moedas = [100, 50, 25, 10, 5, 1] # as moedas tambem
# ====================================================================================================================
# Entrada
# ====================================================================================================================
# Leia um valor de ponto flutuante com duas casas decimais. Este valor representa um valor monetario.
# O arquivo de entrada contém um valor de ponto flutuante N (0 ≤ N ≤ 1000000.00).
# A seguir, calcule o menor numero de notas e moedas possiveis no qual o valor pode ser decomposto.
# ====================================================================================================================
N_valor = float(input())
N_valor = int(N_valor * 100)
# ====================================================================================================================
# Saida
# ====================================================================================================================
# A seguir mostre a relaçao de notas necessarias.
# Imprima a quantidade minima de notas e moedas necessarias para trocar o valor inicial, conforme exemplo fornecido.
# Obs: Utilize ponto (.) para separar a parte decimal.
# ====================================================================================================================
print('NOTAS:')
for nota in tipos_notas:
conta_nota = 0
while nota <= N_valor:
N_valor = N_valor - nota
conta_nota = conta_nota + 1
print('{} nota(s) de R$ {:.2f}'.format(conta_nota, nota/100.0))
print('MOEDAS:')
for moeda in tipos_moedas:
conta_moeda = 0
while moeda <= N_valor:
N_valor = N_valor - moeda
conta_moeda = conta_moeda + 1
print('{} moeda(s) de R$ {:.2f}'.format(conta_moeda, moeda/100.0))
# ========================================================================================================================