parent
b07e06e1a4
commit
9f749cb44a
@ -0,0 +1,100 @@
|
|||||||
|
//-----------Explaination----------
|
||||||
|
|
||||||
|
// Design a cash register drawer function checkCashRegister() that accepts purchase price as the first argument (price), payment as the second argument (cash), and cash-in-drawer (cid) as the third argument.
|
||||||
|
|
||||||
|
// cid is a 2D array listing available currency.
|
||||||
|
|
||||||
|
// The checkCashRegister() function should always return an object with a status key and a change key.
|
||||||
|
|
||||||
|
// Return {status: "INSUFFICIENT_FUNDS", change: []} if cash-in-drawer is less than the change due, or if you cannot return the exact change.
|
||||||
|
|
||||||
|
// Return {status: "CLOSED", change: [...]} with cash-in-drawer as the value for the key change if it is equal to the change due.
|
||||||
|
|
||||||
|
// Otherwise, return {status: "OPEN", change: [...]}, with the change due in coins and bills, sorted in highest to lowest order, as the value of the change key.
|
||||||
|
|
||||||
|
// Currency Unit Amount
|
||||||
|
// Penny $0.01 (PENNY)
|
||||||
|
// Nickel $0.05 (NICKEL)
|
||||||
|
// Dime $0.1 (DIME)
|
||||||
|
// Quarter $0.25 (QUARTER)
|
||||||
|
// Dollar $1 (ONE)
|
||||||
|
// Five Dollars $5 (FIVE)
|
||||||
|
// Ten Dollars $10 (TEN)
|
||||||
|
// Twenty Dollars $20 (TWENTY)
|
||||||
|
// One-hundred Dollars $100 (ONE HUNDRED)
|
||||||
|
// See below for an example of a cash-in-drawer array:
|
||||||
|
|
||||||
|
// [
|
||||||
|
// ["PENNY", 1.01],
|
||||||
|
// ["NICKEL", 2.05],
|
||||||
|
// ["DIME", 3.1],
|
||||||
|
// ["QUARTER", 4.25],
|
||||||
|
// ["ONE", 90],
|
||||||
|
// ["FIVE", 55],
|
||||||
|
// ["TEN", 20],
|
||||||
|
// ["TWENTY", 60],
|
||||||
|
// ["ONE HUNDRED", 100]
|
||||||
|
// ]
|
||||||
|
// Tests
|
||||||
|
// Waiting: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]]) should return an object.
|
||||||
|
// Waiting: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]]) should return {status: "OPEN", change: [["QUARTER", 0.5]]}.
|
||||||
|
// Waiting: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]]) should return {status: "OPEN", change: [["TWENTY", 60], ["TEN", 20], ["FIVE", 15], ["ONE", 1], ["QUARTER", 0.5], ["DIME", 0.2], ["PENNY", 0.04]]}.
|
||||||
|
// Waiting:checkCashRegister(19.5, 20, [["PENNY", 0.01], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 0], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]]) should return {status: "INSUFFICIENT_FUNDS", change: []}.
|
||||||
|
// Waiting:checkCashRegister(19.5, 20, [["PENNY", 0.01], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 1], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]]) should return {status: "INSUFFICIENT_FUNDS", change: []}.
|
||||||
|
// Waiting:checkCashRegister(19.5, 20, [["PENNY", 0.5], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 0], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]]) should return {status: "CLOSED", change: [["PENNY", 0.5], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 0], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]]}.
|
||||||
|
|
||||||
|
//-----------SOLUTION
|
||||||
|
|
||||||
|
var 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 },
|
||||||
|
];
|
||||||
|
|
||||||
|
function checkCashRegister(price, cash, cid) {
|
||||||
|
var output = { status: null, change: [] };
|
||||||
|
var change = cash - price;
|
||||||
|
var 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;
|
||||||
|
}
|
||||||
|
var change_arr = denom.reduce(function (acc, curr) {
|
||||||
|
var 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;
|
||||||
|
}
|
Loading…
Reference in new issue