mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 23:08:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			52 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>A shop is selling candies at a discount. For <strong>every two</strong> candies sold, the shop gives a <strong>third</strong> candy for <strong>free</strong>.</p>
 | |
| 
 | |
| <p>The customer can choose <strong>any</strong> candy to take away for free as long as the cost of the chosen candy is less than or equal to the <strong>minimum</strong> cost of the two candies bought.</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li>For example, if there are <code>4</code> candies with costs <code>1</code>, <code>2</code>, <code>3</code>, and <code>4</code>, and the customer buys candies with costs <code>2</code> and <code>3</code>, they can take the candy with cost <code>1</code> for free, but not the candy with cost <code>4</code>.</li>
 | |
| </ul>
 | |
| 
 | |
| <p>Given a <strong>0-indexed</strong> integer array <code>cost</code>, where <code>cost[i]</code> denotes the cost of the <code>i<sup>th</sup></code> candy, return <em>the <strong>minimum cost</strong> of buying <strong>all</strong> the candies</em>.</p>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong class="example">Example 1:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> cost = [1,2,3]
 | |
| <strong>Output:</strong> 5
 | |
| <strong>Explanation:</strong> We buy the candies with costs 2 and 3, and take the candy with cost 1 for free.
 | |
| The total cost of buying all candies is 2 + 3 = 5. This is the <strong>only</strong> way we can buy the candies.
 | |
| Note that we cannot buy candies with costs 1 and 3, and then take the candy with cost 2 for free.
 | |
| The cost of the free candy has to be less than or equal to the minimum cost of the purchased candies.
 | |
| </pre>
 | |
| 
 | |
| <p><strong class="example">Example 2:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> cost = [6,5,7,9,2,2]
 | |
| <strong>Output:</strong> 23
 | |
| <strong>Explanation:</strong> The way in which we can get the minimum cost is described below:
 | |
| - Buy candies with costs 9 and 7
 | |
| - Take the candy with cost 6 for free
 | |
| - We buy candies with costs 5 and 2
 | |
| - Take the last remaining candy with cost 2 for free
 | |
| Hence, the minimum cost to buy all candies is 9 + 7 + 5 + 2 = 23.
 | |
| </pre>
 | |
| 
 | |
| <p><strong class="example">Example 3:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> cost = [5,5]
 | |
| <strong>Output:</strong> 10
 | |
| <strong>Explanation:</strong> Since there are only 2 candies, we buy both of them. There is not a third candy we can take for free.
 | |
| Hence, the minimum cost to buy all candies is 5 + 5 = 10.
 | |
| </pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>1 <= cost.length <= 100</code></li>
 | |
| 	<li><code>1 <= cost[i] <= 100</code></li>
 | |
| </ul>
 |