Exact Change

  • 题目要求:
    设计一个收银程序 checkCashRegister() ,其把购买价格(price)作为第一个参数 , 付款金额 (cash)作为第二个参数, 和收银机中零钱 (cid) 作为第三个参数.
    cid 是一个二维数组,存着当前可用的找零.
    当收银机中的钱不够找零时返回字符串 "Insufficient Funds". 如果正好则返回字符串 "Closed".
    否则, 返回应找回的零钱列表,且由大到小存在二维数组中.
  • 测试例:
checkCashRegister(19.50, 20.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]]) 应该返回一个数组.

checkCashRegister(19.50, 20.00, [["PENNY", 0.01], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 0], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]]) 应该返回一个字符串.

checkCashRegister(19.50, 20.00, [["PENNY", 0.50], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 0], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]]) 应该返回一个字符串.

checkCashRegister(19.50, 20.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]]) 应该返回 [["QUARTER", 0.50]].

checkCashRegister(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]]) 应该返回 [["TWENTY", 60.00], ["TEN", 20.00], ["FIVE", 15], ["ONE", 1], ["QUARTER", 0.50], ["DIME", 0.20], ["PENNY", 0.04]].

checkCashRegister(19.50, 20.00, [["PENNY", 0.01], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 0], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]]) 应该返回 "Insufficient Funds".

checkCashRegister(19.50, 20.00, [["PENNY", 0.01], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 1.00], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]]) 应该返回 "Insufficient Funds".

checkCashRegister(19.50, 20.00, [["PENNY", 0.50], ["NICKEL", 0], ["DIME", 0], ["QUARTER", 0], ["ONE", 0], ["FIVE", 0], ["TEN", 0], ["TWENTY", 0], ["ONE HUNDRED", 0]]) 应该返回 "Closed".
  • 测试通过代码:
 function checkCashRegister(price, cash, cid) {
        var change = cash - price;
        console.log(change)
        var penny = {
            "PENNY": 0.01,
            "NICKEL": 0.05,
            "DIME": 0.1,
            "QUARTER": 0.25,
            "ONE": 1,
            "FIVE": 5,
            "TEN": 10,
            "TWENTY": 20,
            "ONE HUNDRED": 100
        };

        var pennyValue = {
            0.01: "PENNY",
            0.05: "NICKEL",
            0.1: "DIME",
            0.25: "QUARTER",
            1: "ONE",
            5: "FIVE",
            10: "TEN",
            20: "TWENTY",
            100: "ONE HUNDRED"
        };

        var allMoney = 0;
        cid.map(function (arr1) {
            penny[arr1[0]] = arr1[1];
            allMoney += arr1[1];
        });
        if (allMoney === change) {
            return "Closed";
        }
        var surplus = 0;
        var changeArray = {};

        console.log(penny)
        var flag = false;
        var pennyArray = [0.01, 0.05, 0.1, 0.25, 1, 5, 10, 20, 100];

        function changeSur(change) {
            var pennyArrayChange = pennyArray;
            console.log(pennyArrayChange)
            for (let i = 0; i < pennyArrayChange.length; i++) {
                if (pennyArrayChange[i] > change) {
                    var changeKey = pennyArrayChange[i - 1];
                    var changeValue = pennyValue[changeKey];

                    if (penny[changeValue] >= changeKey) {

                        surplus = change - pennyArrayChange[i - 1];
                        penny[changeValue]=penny[changeValue]-changeKey;

                        flag = true;
                        if (changeArray.hasOwnProperty(changeValue)) {
                            changeArray[changeValue] += changeKey;
                        }
                        else {
                            changeArray[changeValue] = changeKey;
                        }
                        break;
                    } else {
                        pennyArrayChange.splice(i - 1, 1);
                    }

                }
            }
            if (surplus > 0) {
                changeSur(surplus);
            }
            console.log(flag)


        }

        changeSur(change);
        if (!flag) {
            return "Insufficient Funds";
        }
        var returnArray = [];
        var array = Object.keys(changeArray);
        returnArray = array.map(function (x) {
            var arr = [];
            arr.push(x);
            arr.push(changeArray[x]);
            return arr;
        });
        return returnArray;
    }
  • 解析过程:
    最初始终没理解清楚题意,没理解PENNYNICKEL这些代表什么意思,无从下手,后来,发现其实这是零钱的分值,就是["PENNY", 1.01]的意思就是币值为0.01的钱总共有1.01。
    有了这个基础,就很容易得出以下对应关系,实质就是我们理解的数字意义上的币值与名称的对应关系:
var pennyValue = {
            0.01: "PENNY",
            0.05: "NICKEL",
            0.1: "DIME",
            0.25: "QUARTER",
            1: "ONE",
            5: "FIVE",
            10: "TEN",
            20: "TWENTY",
            100: "ONE HUNDRED"
        };

pennyValue 主要用于索引,就是之后输出时需要得值不是0.01这样的,而是PENNY。
由于个人感觉二维数组处理起来不大方便,就使用了penny 来存储币值和总钱数的对应关系,最后输出的时候再进行转换即可。
下来就是纯粹的思路问题了:
先得到所有的零钱,如果所有的零钱加起来刚刚好等于应该找零的钱,返回Closed
使用一个数组,存储了所有的币值,即pennyArray,其内的值从小到大排列。
得到应该找零的钱change,然后遍历pennyArray数组,找到第一个比change大的值,然后取前一个,就是仅比它小或者相等的值,然后去索引penny,看该币值总钱数是否大于等于应该找零的值,如果大于,则得到剩余应该找零的钱surplus,在该币值的钱内减去即将找零的钱,即penny[changeValue]=penny[changeValue]-changeKey;,将flag赋值为true,说明该币值可以找零。

 if (changeArray.hasOwnProperty(changeValue)) {
        changeArray[changeValue] += changeKey;
 }
else {
       changeArray[changeValue] = changeKey;
 }

changeArray是返回的找零数组,填充找零数组中的值。
当循环完成后,如果surplus依旧大于0,则证明找零未完成,继续调用找零函数,如果flag为false,说明现有的零钱不足以找零,返回Insufficient Funds即可。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,242评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,769评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,484评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,133评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,007评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,080评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,496评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,190评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,464评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,549评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,330评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,205评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,567评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,889评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,160评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,475评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,650评论 2 335

推荐阅读更多精彩内容