2018-10-10 18:03:03 -04:00
|
|
|
|
---
|
|
|
|
|
id: aa2e6f85cab2ab736c9a9b24
|
2021-03-14 21:20:39 -06:00
|
|
|
|
title: 计算找零
|
2018-10-10 18:03:03 -04:00
|
|
|
|
challengeType: 5
|
2020-09-07 16:17:22 +08:00
|
|
|
|
forumTopicId: 16012
|
2021-01-13 03:31:00 +01:00
|
|
|
|
dashedName: cash-register
|
2018-10-10 18:03:03 -04:00
|
|
|
|
---
|
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
# --description--
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
请编写一个用于收银机的函数 `checkCashRegister()`:它的第一个参数为售价 `price`、第二个参数为支付金额 `cash`、第三个参数为收银机內的金额 `cid`。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
`cid` 是包含货币面值的二维数组。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
函数 `checkCashRegister()` 应返回含有 `status` 属性和 `change` 属性的对象。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
如果收银机內的金额少于应找回的零钱数,或者你无法返回确切的数目时,返回 `{status: "INSUFFICIENT_FUNDS", change: []}`。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
如果收银机內的金额恰好等于应找回的零钱数,返回 `{status: "CLOSED", change: [...]}`,其中 `change` 的属性值就是收银机內的金额。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
否则,返回 `{status: "OPEN", change: [...]}`,其中 `change` 键值是应找回的零钱数,并将找零的面值由高到低排序。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
<table class='table table-striped'><tbody><tr><th>货币单位 Unit</th><th>面值</th></tr><tr><td>Penny</td><td>0.01 美元(PENNY)</td></tr><tr><td>Nickel</td><td>0.05 美元(NICKEL)</td></tr><tr><td>Dime</td><td>0.1 美元(DIME)</td></tr><tr><td>Quarter</td><td>0.25 美元(QUARTER)</td></tr><tr><td>Dollar</td><td>1 美元(ONE)</td></tr><tr><td>Five Dollars</td><td>5 美元(五)</td></tr><tr><td>Ten Dollars</td><td>10 美元(TEN)</td></tr><tr><td>Twenty Dollars</td><td>20 美元(TWENTY)</td></tr><tr><td>One-hundred Dollars</td><td>100美元(ONE HUNDRED)</td></tr></tbody></table>
|
2021-01-12 08:18:51 -08:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
下面的抽屉里现金数组示例:
|
2021-01-12 08:18:51 -08:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
[
|
|
|
|
|
["PENNY", 1.01],
|
|
|
|
|
["NICKEL", 2.05],
|
|
|
|
|
["DIME", 3.1],
|
|
|
|
|
["QUARTER", 4.25],
|
|
|
|
|
["ONE", 90],
|
|
|
|
|
["FIVE", 55],
|
|
|
|
|
["TEN", 20],
|
|
|
|
|
["TWENTY", 60],
|
|
|
|
|
["ONE HUNDRED", 100]
|
|
|
|
|
]
|
|
|
|
|
```
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
# --hints--
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
`checkCashRegister(19.5, 20, [["PENNY", 1.01], ["NICKEL", 2.05], ["DIME", 3.1], ["QUARTER", 4.25], ["ONE", 90], ["FIVE", 55], ["TEN", 20], ["TWENTY", 60], ["ONE HUNDRED", 100]])` 应返回一个对象。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert.deepEqual(
|
|
|
|
|
Object.prototype.toString.call(
|
|
|
|
|
checkCashRegister(19.5, 20, [
|
|
|
|
|
['PENNY', 1.01],
|
|
|
|
|
['NICKEL', 2.05],
|
|
|
|
|
['DIME', 3.1],
|
|
|
|
|
['QUARTER', 4.25],
|
|
|
|
|
['ONE', 90],
|
|
|
|
|
['FIVE', 55],
|
|
|
|
|
['TEN', 20],
|
|
|
|
|
['TWENTY', 60],
|
|
|
|
|
['ONE HUNDRED', 100]
|
|
|
|
|
])
|
|
|
|
|
),
|
|
|
|
|
'[object Object]'
|
|
|
|
|
);
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
`checkCashRegister(19.5, 20, [["PENNY", 1.01], ["NICKEL", 2.05], ["DIME", 3.1], ["QUARTER", 4.25], ["ONE", 90], ["FIVE", 55], ["TEN", 20], ["TWENTY", 60], ["ONE HUNDRED", 100]])` 应返回 `{status: "OPEN", change: [["QUARTER", 0.5]]}`。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
|
assert.deepEqual(
|
|
|
|
|
checkCashRegister(19.5, 20, [
|
|
|
|
|
['PENNY', 1.01],
|
|
|
|
|
['NICKEL', 2.05],
|
|
|
|
|
['DIME', 3.1],
|
|
|
|
|
['QUARTER', 4.25],
|
|
|
|
|
['ONE', 90],
|
|
|
|
|
['FIVE', 55],
|
|
|
|
|
['TEN', 20],
|
|
|
|
|
['TWENTY', 60],
|
|
|
|
|
['ONE HUNDRED', 100]
|
|
|
|
|
]),
|
|
|
|
|
{ status: 'OPEN', change: [['QUARTER', 0.5]] }
|
|
|
|
|
);
|
2018-10-10 18:03:03 -04:00
|
|
|
|
```
|
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
`checkCashRegister(3.26, 100, [["PENNY", 1.01], ["NICKEL", 2.05], ["DIME", 3.1], ["QUARTER", 4.25], ["ONE", 90], ["FIVE", 55], ["TEN", 20], ["TWENTY", 60], ["ONE HUNDRED", 100]])` 应返回 `{status: "OPEN", change: [["TWENTY", 60], ["TEN", 20], ["FIVE", 15], ["ONE", 1], ["QUARTER", 0.5], ["DIME", 0.2], ["PENNY", 0.04]]}`。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert.deepEqual(
|
|
|
|
|
checkCashRegister(3.26, 100, [
|
|
|
|
|
['PENNY', 1.01],
|
|
|
|
|
['NICKEL', 2.05],
|
|
|
|
|
['DIME', 3.1],
|
|
|
|
|
['QUARTER', 4.25],
|
|
|
|
|
['ONE', 90],
|
|
|
|
|
['FIVE', 55],
|
|
|
|
|
['TEN', 20],
|
|
|
|
|
['TWENTY', 60],
|
|
|
|
|
['ONE HUNDRED', 100]
|
|
|
|
|
]),
|
|
|
|
|
{
|
|
|
|
|
status: 'OPEN',
|
|
|
|
|
change: [
|
|
|
|
|
['TWENTY', 60],
|
|
|
|
|
['TEN', 20],
|
|
|
|
|
['FIVE', 15],
|
|
|
|
|
['ONE', 1],
|
|
|
|
|
['QUARTER', 0.5],
|
|
|
|
|
['DIME', 0.2],
|
|
|
|
|
['PENNY', 0.04]
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
`checkCashRegister(19.5, 20, [["PENNY", 0.01], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 0], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]])` 应返回 `{status: "INSUFFICIENT_FUNDS", change: []}`。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert.deepEqual(
|
|
|
|
|
checkCashRegister(19.5, 20, [
|
|
|
|
|
['PENNY', 0.01],
|
|
|
|
|
['NICKEL', 0],
|
|
|
|
|
['DIME', 0],
|
|
|
|
|
['QUARTER', 0],
|
|
|
|
|
['ONE', 0],
|
|
|
|
|
['FIVE', 0],
|
|
|
|
|
['TEN', 0],
|
|
|
|
|
['TWENTY', 0],
|
|
|
|
|
['ONE HUNDRED', 0]
|
|
|
|
|
]),
|
|
|
|
|
{ status: 'INSUFFICIENT_FUNDS', change: [] }
|
|
|
|
|
);
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
`checkCashRegister(19.5, 20, [["PENNY", 0.01], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 1], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]])` 应返回 `{status: "INSUFFICIENT_FUNDS", change: []}`。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert.deepEqual(
|
|
|
|
|
checkCashRegister(19.5, 20, [
|
|
|
|
|
['PENNY', 0.01],
|
|
|
|
|
['NICKEL', 0],
|
|
|
|
|
['DIME', 0],
|
|
|
|
|
['QUARTER', 0],
|
|
|
|
|
['ONE', 1],
|
|
|
|
|
['FIVE', 0],
|
|
|
|
|
['TEN', 0],
|
|
|
|
|
['TWENTY', 0],
|
|
|
|
|
['ONE HUNDRED', 0]
|
|
|
|
|
]),
|
|
|
|
|
{ status: 'INSUFFICIENT_FUNDS', change: [] }
|
|
|
|
|
);
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-03-14 21:20:39 -06:00
|
|
|
|
`checkCashRegister(19.5, 20, [["PENNY", 0.5], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 0], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]])` 应返回 `{status: "CLOSED", change: [["PENNY", 0.5], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 0], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]]}`。
|
2020-09-07 16:17:22 +08:00
|
|
|
|
|
2018-10-10 18:03:03 -04:00
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
|
assert.deepEqual(
|
|
|
|
|
checkCashRegister(19.5, 20, [
|
|
|
|
|
['PENNY', 0.5],
|
|
|
|
|
['NICKEL', 0],
|
|
|
|
|
['DIME', 0],
|
|
|
|
|
['QUARTER', 0],
|
|
|
|
|
['ONE', 0],
|
|
|
|
|
['FIVE', 0],
|
|
|
|
|
['TEN', 0],
|
|
|
|
|
['TWENTY', 0],
|
|
|
|
|
['ONE HUNDRED', 0]
|
|
|
|
|
]),
|
|
|
|
|
{
|
|
|
|
|
status: 'CLOSED',
|
|
|
|
|
change: [
|
|
|
|
|
['PENNY', 0.5],
|
|
|
|
|
['NICKEL', 0],
|
|
|
|
|
['DIME', 0],
|
|
|
|
|
['QUARTER', 0],
|
|
|
|
|
['ONE', 0],
|
|
|
|
|
['FIVE', 0],
|
|
|
|
|
['TEN', 0],
|
|
|
|
|
['TWENTY', 0],
|
|
|
|
|
['ONE HUNDRED', 0]
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
);
|
2018-10-10 18:03:03 -04:00
|
|
|
|
```
|
2020-08-13 17:24:35 +02:00
|
|
|
|
|
2021-01-13 03:31:00 +01:00
|
|
|
|
# --seed--
|
|
|
|
|
|
|
|
|
|
## --seed-contents--
|
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
function checkCashRegister(price, cash, cid) {
|
2021-10-27 15:10:57 +00:00
|
|
|
|
let change;
|
2021-01-13 03:31:00 +01:00
|
|
|
|
return change;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
checkCashRegister(19.5, 20, [["PENNY", 1.01], ["NICKEL", 2.05], ["DIME", 3.1], ["QUARTER", 4.25], ["ONE", 90], ["FIVE", 55], ["TEN", 20], ["TWENTY", 60], ["ONE HUNDRED", 100]]);
|
|
|
|
|
```
|
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
# --solutions--
|
|
|
|
|
|
2021-01-13 03:31:00 +01:00
|
|
|
|
```js
|
2021-10-27 15:10:57 +00:00
|
|
|
|
const denom = [
|
|
|
|
|
{ name: "ONE HUNDRED", val: 100 },
|
|
|
|
|
{ name: "TWENTY", val: 20 },
|
|
|
|
|
{ name: "TEN", val: 10 },
|
|
|
|
|
{ name: "FIVE", val: 5 },
|
|
|
|
|
{ name: "ONE", val: 1 },
|
|
|
|
|
{ name: "QUARTER", val: 0.25 },
|
|
|
|
|
{ name: "DIME", val: 0.1 },
|
|
|
|
|
{ name: "NICKEL", val: 0.05 },
|
|
|
|
|
{ name: "PENNY", val: 0.01 },
|
2021-01-13 03:31:00 +01:00
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
function checkCashRegister(price, cash, cid) {
|
2021-10-27 15:10:57 +00:00
|
|
|
|
const output = { status: null, change: [] };
|
|
|
|
|
let change = cash - price;
|
|
|
|
|
const register = cid.reduce(
|
|
|
|
|
function (acc, curr) {
|
|
|
|
|
acc.total += curr[1];
|
|
|
|
|
acc[curr[0]] = curr[1];
|
|
|
|
|
return acc;
|
|
|
|
|
},
|
|
|
|
|
{ total: 0 }
|
|
|
|
|
);
|
|
|
|
|
if (register.total === change) {
|
|
|
|
|
output.status = "CLOSED";
|
|
|
|
|
output.change = cid;
|
|
|
|
|
return output;
|
|
|
|
|
}
|
|
|
|
|
if (register.total < change) {
|
|
|
|
|
output.status = "INSUFFICIENT_FUNDS";
|
|
|
|
|
return output;
|
|
|
|
|
}
|
|
|
|
|
const change_arr = denom.reduce(function (acc, curr) {
|
|
|
|
|
let value = 0;
|
|
|
|
|
while (register[curr.name] > 0 && change >= curr.val) {
|
|
|
|
|
change -= curr.val;
|
|
|
|
|
register[curr.name] -= curr.val;
|
|
|
|
|
value += curr.val;
|
|
|
|
|
change = Math.round(change * 100) / 100;
|
|
|
|
|
}
|
|
|
|
|
if (value > 0) {
|
|
|
|
|
acc.push([curr.name, value]);
|
|
|
|
|
}
|
|
|
|
|
return acc;
|
|
|
|
|
}, []);
|
|
|
|
|
if (change_arr.length < 1 || change > 0) {
|
|
|
|
|
output.status = "INSUFFICIENT_FUNDS";
|
|
|
|
|
return output;
|
|
|
|
|
}
|
|
|
|
|
output.status = "OPEN";
|
|
|
|
|
output.change = change_arr;
|
|
|
|
|
return output;
|
2021-01-13 03:31:00 +01:00
|
|
|
|
}
|
|
|
|
|
```
|