1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-11 02:58:13 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/每隔 n 个顾客打折 [apply-discount-every-n-orders].html

55 lines
3.8 KiB
HTML
Raw Normal View History

2022-03-27 20:37:52 +08:00
<p>超市里正在举行打折活动,每隔&nbsp;<code>n</code>&nbsp;个顾客会得到 <code>discount</code>&nbsp;的折扣。</p>
<p>超市里有一些商品,第&nbsp;<code>i</code>&nbsp;种商品为&nbsp;<code>products[i]</code>&nbsp;且每件单品的价格为&nbsp;<code>prices[i]</code>&nbsp;</p>
<p>结账系统会统计顾客的数目,每隔&nbsp;<code>n</code>&nbsp;个顾客结账时,该顾客的账单都会打折,折扣为&nbsp;<code>discount</code>&nbsp;(也就是如果原本账单为&nbsp;<code>x</code>&nbsp;,那么实际金额会变成&nbsp;<code>x - (discount * x) / 100</code>&nbsp;),然后系统会重新开始计数。</p>
<p>顾客会购买一些商品,&nbsp;<code>product[i]</code>&nbsp;是顾客购买的第&nbsp;<code>i</code>&nbsp;种商品,&nbsp;<code>amount[i]</code>&nbsp;是对应的购买该种商品的数目。</p>
<p>请你实现&nbsp;<code>Cashier</code>&nbsp;类:</p>
<ul>
<li><code>Cashier(int n, int discount, int[] products, int[] prices)</code>&nbsp;初始化实例对象,参数分别为打折频率&nbsp;<code>n</code>&nbsp;,折扣大小 <code>discount</code>&nbsp;,超市里的商品列表 <code>products</code>&nbsp;和它们的价格 <code>prices</code>&nbsp;</li>
<li><code>double&nbsp;getBill(int[] product, int[] amount)</code>&nbsp;返回账单的实际金额(如果有打折,请返回打折后的结果)。返回结果与标准答案误差在&nbsp;<code>10^-5</code>&nbsp;以内都视为正确结果。</li>
</ul>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<pre><strong>输入</strong>
[&quot;Cashier&quot;,&quot;getBill&quot;,&quot;getBill&quot;,&quot;getBill&quot;,&quot;getBill&quot;,&quot;getBill&quot;,&quot;getBill&quot;,&quot;getBill&quot;]
[[3,50,[1,2,3,4,5,6,7],[100,200,300,400,300,200,100]],[[1,2],[1,2]],[[3,7],[10,10]],[[1,2,3,4,5,6,7],[1,1,1,1,1,1,1]],[[4],[10]],[[7,3],[10,10]],[[7,5,3,1,6,4,2],[10,10,10,9,9,9,7]],[[2,3,5],[5,3,2]]]
<strong>输出</strong>
[null,500.0,4000.0,800.0,4000.0,4000.0,7350.0,2500.0]
<strong>解释</strong>
Cashier cashier = new Cashier(3,50,[1,2,3,4,5,6,7],[100,200,300,400,300,200,100]);
cashier.getBill([1,2],[1,2]); // 返回 500.0, 账单金额为 = 1 * 100 + 2 * 200 = 500.
cashier.getBill([3,7],[10,10]); // 返回 4000.0
cashier.getBill([1,2,3,4,5,6,7],[1,1,1,1,1,1,1]); // 返回 800.0 ,账单原本为 1600.0 ,但由于该顾客是第三位顾客,他将得到 50% 的折扣,所以实际金额为 1600 - 1600 * (50 / 100) = 800 。
cashier.getBill([4],[10]); // 返回 4000.0
cashier.getBill([7,3],[10,10]); // 返回 4000.0
cashier.getBill([7,5,3,1,6,4,2],[10,10,10,9,9,9,7]); // 返回 7350.0 ,账单原本为 14700.0 ,但由于系统计数再次达到三,该顾客将得到 50% 的折扣,实际金额为 7350.0 。
cashier.getBill([2,3,5],[5,3,2]); // 返回 2500.0
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>1 &lt;= n &lt;= 10^4</code></li>
<li><code>0 &lt;= discount &lt;= 100</code></li>
<li><code>1 &lt;= products.length &lt;= 200</code></li>
<li><code>1 &lt;= products[i] &lt;= 200</code></li>
<li><code>products</code>&nbsp;列表中&nbsp;<strong>不会</strong>&nbsp;有重复的元素。</li>
<li><code>prices.length == products.length</code></li>
<li><code>1 &lt;= prices[i] &lt;= 1000</code></li>
<li><code>1 &lt;= product.length &lt;= products.length</code></li>
<li><code>product[i]</code>&nbsp;&nbsp;<code>products</code>&nbsp;出现过。</li>
<li><code>amount.length == product.length</code></li>
<li><code>1 &lt;= amount[i] &lt;= 1000</code></li>
<li>最多有&nbsp;<code>1000</code> 次对&nbsp;<code>getBill</code>&nbsp;函数的调用。</li>
<li>返回结果与标准答案误差在&nbsp;<code>10^-5</code>&nbsp;以内都视为正确结果。</li>
</ul>