我正在努力应对来自在线编码社区的挑战。 目的是编写一个生成精确变化的函数 使用表示的面额从最高到最低 CID阵列(现金抽屉)。该功能需要三个 论据,价格,现金,cid。 Cid是抽屉里的现金。
我正在试图比较现金数额 cid的现金数额 精确的变化计算。
例如,如果更改= 96,则从最高位置更改为 最低的将是
['twenty', 80], ['ten', 1], ['five', 1],
['one', 1]
。但是,如果CID显示['二十',60],['十',二十],[“五,55]那么 代码必须使用cid中的金额计算确切的更改。 在这种情况下,结果将是,
['twenty', 60], ['ten', 20],
['five', 15], ['one', 1]
在下面的代码中,display()函数包含一个条件语句 用于进行比较并切换CID值 如有必要。但是,这会导致重复值 [“TWENTY”]出现。我的问题是造成这种情况的原因 我该如何解决呢。
该函数的输入产生错误的结果:
[ [ 'TWENTY', 60 ],
[ 'TWENTY', 20 ],
[ 'TEN', 10 ],
[ 'FIVE', 5 ],
[ 'ONE', 1 ],
[ 'QUARTER', 0.5 ],
[ 'DIME', 0.2 ],
[ 'PENNY', 0.04 ] ]
我已经包含了下面的代码,但我已经建立了一个模型] 在http://repl.it/BAku/2。
function drawer(price, cash, cid){
var change = cash - price;
change = change.toFixed(2);
change = +change;
var combine = [];
var cidMap = [ cid[0], cid[1], cid[2], cid[3], cid[4], cid[5], cid[6], cid[7], cid[8] ];
var denomMap = [
100, 'ONE HUNDRED', 20, 'TWENTY', 10, 'TEN', 5, 'FIVE', 1, 'ONE', 0.25, 'QUARTER', 0.1, 'DIME', 0.05, 'NICKEL', 0.01, "PENNY"
];
function total(cid){
var cashAmts = [];
cid.forEach(function(v){
cashAmts.push(v[1]);
},0);
var sum = cashAmts.reduce(function(a, b){return a + b;
}).toFixed(2);
return +sum;
}
if(cash < price){
return price;
}
else if(total(cid) < change){
return "Insufficient Funds";
}
else if(total(cid) === change){
return "Closed";
}
else if(total(cid) > change){
return display(change, cid);
}
function display(change) {
var temp;
num = change;
var num = change;
var value = '';
for (var i = 0; change > 0 && i < denomMap.length; i += 2) {
while (change >= denomMap[i]) {
change += denomMap[i + 1];
change = change.replace(/\d+/g, "");
change = change.replace(/\./g, "");
value += denomMap[i];
var div = Math.floor(num/+value) * denomMap[i];
if(change === cidMap[0][0] && div > cidMap[0][1]){
div = cidMap[0][1];
}
else if(change === cidMap[1][0] && div > cidMap[1][1]){
div = cidMap[1][1];
}
else if(change === cidMap[2][0] && div > cidMap[2][1]){
div = cidMap[2][1];
}
else if(change === cidMap[3][0] && div > cidMap[3][1]){
div = cidMap[3][1];
}
else if(change === cidMap[4][0] && div > cidMap[4][1]){
div = cidMap[4][1];
}
else if(change === cidMap[5][0] && div > cidMap[5][1]){
div = cidMap[5][1];
}
else if(change === cidMap[6][0] && div > cidMap[6][1]){
div = cidMap[6][1];
}
else if(change === cidMap[7][0] && div > cidMap[7][1]){
div = cidMap[7][1];
}
else if(change === cidMap[8][0] && div > cidMap[8][1]){
div = cidMap[8][1];
}
temp = [change, div];
combine.push(temp);
num = (num - div).toFixed(2);
num = +num;
display(num);
}
}
return combine;
}
}
drawer(3.26, 100.00, [['PENNY', 1.01], ['NICKEL', 2.05], ['DIME', 3.10], ['QUARTER', 4.25], ['ONE', 90.00], ['FIVE', 55.00], ['TEN', 20.00], ['TWENTY', 60.00], ['ONE HUNDRED', 100.00]]);
答案 0 :(得分:1)
造成这种情况的原因是什么?
您正在从抽屉中取出所有三个{guid}
音符,但不更新抽屉以反映现在没有留下'TWENTY'
个音符。因此,在下一次循环迭代中,抽屉错误地认为您还有另一个'TWENTY'
注释。
我该如何解决?
取款后更新抽屉中的现金,并附上剩余现金支票。这是一种方法,只需对原始代码进行最少的修改即可为您提供一些见解。
记下'TWENTY'
函数及其调用位置。另请注意抽屉的更新(例如,有三个changeAvailable
注释:TWENTY
)。
http://jsbin.com/vapobu/edit?js,console
cidMap[7][1] = 0;