## 問題 商品名と支払い金額を入力すると、お釣りの「小銭の枚数」を返す関数またはメソッドを実装せよ。商品名と価格は以下の通り。 * お茶: 120円 * コーラ: 150円 * エナジードリンク: 280円 入力される通貨は日本円で、最大1000円までとする。 また、有効な貨幣は「1000円」「500円」「100円」「50円」「10円」とする。 たとえば、「1000円でお茶を購入」すると、返却すべき金額は880円だが、釣銭は「500円×1, 100円×3, 50円×1, 10円×3」となる。返り値は、任意の形式のクラス、連想配列、オブジェクト、構造体、リストなどで表現してよい。 PHPの擬似コードで書くと以下のようになる。 ```php function calcChange(string $item, int $paid_money): array { // ... } $expected = [500 => 1, 100 => 3, 50 => 1, 10 => 3]; assert($expected === calcChange("お茶", 1000)); ``` ```python class NotEnoughException(Exception): pass item_cost = {"お茶": 120, "コーラ": 150, "エナジードリンク": 280} def (item: str, paid_money: int): # 支払いが足りない if paid_money - item_cost[item] < 0: raise NotEnoughException("支払い金額が足りません") # お釣りの金額 change_value = paid_money - item_cost[item] coins = {1000:0, 500:0, 100:0, 50:0, 10:0} for coin in coins.keys(): while change_value >= coin: change_value = change_value - coin coins[coin] +=1 return coins ```