-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdesign_an_ATM_machine.py
103 lines (82 loc) · 4.73 KB
/
design_an_ATM_machine.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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
# There is an ATM machine that stores banknotes of 5 denominations: 20, 50, 100, 200, and 500 dollars. Initially the ATM is empty.
# The user can use the machine to deposit or withdraw any amount of money.
# When withdrawing, the machine prioritizes using banknotes of larger values.
# For example, if you want to withdraw $300 and there are 2 $50 banknotes, 1 $100 banknote, and 1 $200 banknote, then the machine will
# use the $100 and $200 banknotes.
# However, if you try to withdraw $600 and there are 3 $200 banknotes and 1 $500 banknote, then the withdraw request will be rejected
# because the machine will first try to use the $500 banknote and then be unable to use banknotes to complete the remaining $100. Note
# that the machine is not allowed to use the $200 banknotes instead of the $500 banknote.
# Implement the ATM class:
# ATM() Initializes the ATM object.
# void deposit(int[] banknotesCount) Deposits new banknotes in the order $20, $50, $100, $200, and $500.
# int[] withdraw(int amount) Returns an array of length 5 of the number of banknotes that will be handed to the user in the order $20, $50,
# $100, $200, and $500, and update the number of banknotes in the ATM after withdrawing. Returns [-1] if it is not possible (do not withdraw
# any banknotes in this case).
# Example 1:
# Input
# ["ATM", "deposit", "withdraw", "deposit", "withdraw", "withdraw"]
# [[], [[0,0,1,2,1]], [600], [[0,1,0,1,1]], [600], [550]]
# Output
# [null, null, [0,0,1,0,1], null, [-1], [0,1,0,0,1]]
# Explanation
# ATM atm = new ATM();
# atm.deposit([0,0,1,2,1]); // Deposits 1 $100 banknote, 2 $200 banknotes,
# // and 1 $500 banknote.
# atm.withdraw(600); // Returns [0,0,1,0,1]. The machine uses 1 $100 banknote
# // and 1 $500 banknote. The banknotes left over in the
# // machine are [0,0,0,2,0].
# atm.deposit([0,1,0,1,1]); // Deposits 1 $50, $200, and $500 banknote.
# // The banknotes in the machine are now [0,1,0,3,1].
# atm.withdraw(600); // Returns [-1]. The machine will try to use a $500 banknote
# // and then be unable to complete the remaining $100,
# // so the withdraw request will be rejected.
# // Since the request is rejected, the number of banknotes
# // in the machine is not modified.
# atm.withdraw(550); // Returns [0,1,0,0,1]. The machine uses 1 $50 banknote
# // and 1 $500 banknote.
class ATM:
def __init__(self):
self.NotesInStorage = {}
self.Notes = [20, 50, 100, 200, 500]
def deposit(self, banknotesCount: List[int]) -> None:
for i in range(len(banknotesCount)):
if banknotesCount[i] == 0:
continue
if self.Notes[i] not in self.NotesInStorage:
self.NotesInStorage[self.Notes[i]] = banknotesCount[i]
else:
self.NotesInStorage[self.Notes[i]] += banknotesCount[i]
def withdraw(self, amount: int) -> List[int]:
storageBeforeOperation = []
for i in range(len(self.Notes)):
if self.Notes[i] in self.NotesInStorage:
storageBeforeOperation.append(self.NotesInStorage[self.Notes[i]])
else:
storageBeforeOperation.append(0)
returnNotes = []
for i in reversed(range(len(self.Notes))):
if self.Notes[i] in self.NotesInStorage and self.NotesInStorage[self.Notes[i]] != 0:
multiple = amount // self.Notes[i]
if multiple == 0:
returnNotes.insert(0, 0)
else:
if multiple >= self.NotesInStorage[self.Notes[i]]:
returnNotes.insert(0, self.NotesInStorage[self.Notes[i]])
amount -= (self.Notes[i] * self.NotesInStorage[self.Notes[i]])
self.NotesInStorage[self.Notes[i]] = 0
else:
returnNotes.insert(0, multiple)
amount -= (multiple * self.Notes[i])
self.NotesInStorage[self.Notes[i]] = (self.NotesInStorage[self.Notes[i]] - multiple)
else:
returnNotes.insert(0, 0)
if amount != 0:
for i in range(len(self.Notes)):
if storageBeforeOperation[i] != 0:
self.NotesInStorage[self.Notes[i]] = storageBeforeOperation[i]
return [-1]
return returnNotes
# Your ATM object will be instantiated and called as such:
# obj = ATM()
# obj.deposit(banknotesCount)
# param_2 = obj.withdraw(amount)