mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 23:08:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			68 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>You have the task of delivering some boxes from storage to their ports using only one ship. However, this ship has a <strong>limit</strong> on the <strong>number of boxes</strong> and the <strong>total weight</strong> that it can carry.</p>
 | ||
| 
 | ||
| <p>You are given an array <code>boxes</code>, where <code>boxes[i] = [ports<sub>i</sub>, weight<sub>i</sub>]</code>, and three integers <code>portsCount</code>, <code>maxBoxes</code>, and <code>maxWeight</code>.</p>
 | ||
| 
 | ||
| <ul>
 | ||
| 	<li><code>ports<sub>i</sub></code> is the port where you need to deliver the <code>i<sup>th</sup></code> box and <code>weights<sub>i</sub></code> is the weight of the <code>i<sup>th</sup></code> box.</li>
 | ||
| 	<li><code>portsCount</code> is the number of ports.</li>
 | ||
| 	<li><code>maxBoxes</code> and <code>maxWeight</code> are the respective box and weight limits of the ship.</li>
 | ||
| </ul>
 | ||
| 
 | ||
| <p>The boxes need to be delivered <strong>in the order they are given</strong>. The ship will follow these steps:</p>
 | ||
| 
 | ||
| <ul>
 | ||
| 	<li>The ship will take some number of boxes from the <code>boxes</code> queue, not violating the <code>maxBoxes</code> and <code>maxWeight</code> constraints.</li>
 | ||
| 	<li>For each loaded box <strong>in order</strong>, the ship will make a <strong>trip</strong> to the port the box needs to be delivered to and deliver it. If the ship is already at the correct port, no <strong>trip</strong> is needed, and the box can immediately be delivered.</li>
 | ||
| 	<li>The ship then makes a return <strong>trip</strong> to storage to take more boxes from the queue.</li>
 | ||
| </ul>
 | ||
| 
 | ||
| <p>The ship must end at storage after all the boxes have been delivered.</p>
 | ||
| 
 | ||
| <p>Return <em>the <strong>minimum</strong> number of <strong>trips</strong> the ship needs to make to deliver all boxes to their respective ports.</em></p>
 | ||
| 
 | ||
| <p> </p>
 | ||
| <p><strong class="example">Example 1:</strong></p>
 | ||
| 
 | ||
| <pre>
 | ||
| <strong>Input:</strong> boxes = [[1,1],[2,1],[1,1]], portsCount = 2, maxBoxes = 3, maxWeight = 3
 | ||
| <strong>Output:</strong> 4
 | ||
| <strong>Explanation:</strong> The optimal strategy is as follows: 
 | ||
| - The ship takes all the boxes in the queue, goes to port 1, then port 2, then port 1 again, then returns to storage. 4 trips.
 | ||
| So the total number of trips is 4.
 | ||
| Note that the first and third boxes cannot be delivered together because the boxes need to be delivered in order (i.e. the second box needs to be delivered at port 2 before the third box).
 | ||
| </pre>
 | ||
| 
 | ||
| <p><strong class="example">Example 2:</strong></p>
 | ||
| 
 | ||
| <pre>
 | ||
| <strong>Input:</strong> boxes = [[1,2],[3,3],[3,1],[3,1],[2,4]], portsCount = 3, maxBoxes = 3, maxWeight = 6
 | ||
| <strong>Output:</strong> 6
 | ||
| <strong>Explanation:</strong> The optimal strategy is as follows: 
 | ||
| - The ship takes the first box, goes to port 1, then returns to storage. 2 trips.
 | ||
| - The ship takes the second, third and fourth boxes, goes to port 3, then returns to storage. 2 trips.
 | ||
| - The ship takes the fifth box, goes to port 2, then returns to storage. 2 trips.
 | ||
| So the total number of trips is 2 + 2 + 2 = 6.
 | ||
| </pre>
 | ||
| 
 | ||
| <p><strong class="example">Example 3:</strong></p>
 | ||
| 
 | ||
| <pre>
 | ||
| <strong>Input:</strong> boxes = [[1,4],[1,2],[2,1],[2,1],[3,2],[3,4]], portsCount = 3, maxBoxes = 6, maxWeight = 7
 | ||
| <strong>Output:</strong> 6
 | ||
| <strong>Explanation:</strong> The optimal strategy is as follows:
 | ||
| - The ship takes the first and second boxes, goes to port 1, then returns to storage. 2 trips.
 | ||
| - The ship takes the third and fourth boxes, goes to port 2, then returns to storage. 2 trips.
 | ||
| - The ship takes the fifth and sixth boxes, goes to port 3, then returns to storage. 2 trips.
 | ||
| So the total number of trips is 2 + 2 + 2 = 6.
 | ||
| </pre>
 | ||
| 
 | ||
| <p> </p>
 | ||
| <p><strong>Constraints:</strong></p>
 | ||
| 
 | ||
| <ul>
 | ||
| 	<li><code>1 <= boxes.length <= 10<sup>5</sup></code></li>
 | ||
| 	<li><code>1 <= portsCount, maxBoxes, maxWeight <= 10<sup>5</sup></code></li>
 | ||
| 	<li><code>1 <= ports<sub>i</sub> <= portsCount</code></li>
 | ||
| 	<li><code>1 <= weights<sub>i</sub> <= maxWeight</code></li>
 | ||
| </ul>
 |