860. 柠檬水找零

💡 原文英文,约700词,阅读约需3分钟。
📝

内容提要

这篇文章讲述了一个关于柠檬水找零的问题。顾客在柠檬水摊位上购买柠檬水,每杯柠檬水的价格为5美元。顾客按照账单的顺序依次购买,每个顾客只购买一杯柠檬水,并用5美元、10美元或20美元的钞票支付。文章提供了一个整数数组bills,其中bills[i]表示第i个顾客支付的账单。如果能够给每个顾客正确找零,则返回true,否则返回false。解决方案是模拟给顾客找零的过程,并跟踪手中的5美元和10美元的数量。如果成功处理所有顾客而不用找零,则返回true。

🎯

关键要点

  • 柠檬水每杯售价为5美元,顾客依次购买并支付。
  • 顾客可以使用5美元、10美元或20美元的钞票支付。
  • 需要正确找零给每位顾客,若能做到则返回true,否则返回false。
  • 解决方案是模拟找零过程,跟踪手中5美元和10美元的数量。
  • 支付5美元时,增加5美元的数量;支付10美元时,减少1个5美元;支付20美元时,优先用1个10美元和1个5美元找零。
  • 如果没有足够的钞票找零,则返回false。
  • 函数应处理无法找零的边界情况,并高效处理大输入规模,时间复杂度为O(n)。
➡️

继续阅读