mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-10 18:48:13 +08:00
55 lines
3.1 KiB
HTML
55 lines
3.1 KiB
HTML
<p>Fruits are available at some positions on an infinite x-axis. You are given a 2D integer array <code>fruits</code> where <code>fruits[i] = [position<sub>i</sub>, amount<sub>i</sub>]</code> depicts <code>amount<sub>i</sub></code> fruits at the position <code>position<sub>i</sub></code>. <code>fruits</code> is already <strong>sorted</strong> by <code>position<sub>i</sub></code> in <strong>ascending order</strong>, and each <code>position<sub>i</sub></code> is <strong>unique</strong>.</p>
|
|
|
|
<p>You are also given an integer <code>startPos</code> and an integer <code>k</code>. Initially, you are at the position <code>startPos</code>. From any position, you can either walk to the <strong>left or right</strong>. It takes <strong>one step</strong> to move <strong>one unit</strong> on the x-axis, and you can walk <strong>at most</strong> <code>k</code> steps in total. For every position you reach, you harvest all the fruits at that position, and the fruits will disappear from that position.</p>
|
|
|
|
<p>Return <em>the <strong>maximum total number</strong> of fruits you can harvest</em>.</p>
|
|
|
|
<p> </p>
|
|
<p><strong>Example 1:</strong></p>
|
|
<img alt="" src="https://assets.leetcode.com/uploads/2021/11/21/1.png" style="width: 472px; height: 115px;" />
|
|
<pre>
|
|
<strong>Input:</strong> fruits = [[2,8],[6,3],[8,6]], startPos = 5, k = 4
|
|
<strong>Output:</strong> 9
|
|
<strong>Explanation:</strong>
|
|
The optimal way is to:
|
|
- Move right to position 6 and harvest 3 fruits
|
|
- Move right to position 8 and harvest 6 fruits
|
|
You moved 3 steps and harvested 3 + 6 = 9 fruits in total.
|
|
</pre>
|
|
|
|
<p><strong>Example 2:</strong></p>
|
|
<img alt="" src="https://assets.leetcode.com/uploads/2021/11/21/2.png" style="width: 512px; height: 129px;" />
|
|
<pre>
|
|
<strong>Input:</strong> fruits = [[0,9],[4,1],[5,7],[6,2],[7,4],[10,9]], startPos = 5, k = 4
|
|
<strong>Output:</strong> 14
|
|
<strong>Explanation:</strong>
|
|
You can move at most k = 4 steps, so you cannot reach position 0 nor 10.
|
|
The optimal way is to:
|
|
- Harvest the 7 fruits at the starting position 5
|
|
- Move left to position 4 and harvest 1 fruit
|
|
- Move right to position 6 and harvest 2 fruits
|
|
- Move right to position 7 and harvest 4 fruits
|
|
You moved 1 + 3 = 4 steps and harvested 7 + 1 + 2 + 4 = 14 fruits in total.
|
|
</pre>
|
|
|
|
<p><strong>Example 3:</strong></p>
|
|
<img alt="" src="https://assets.leetcode.com/uploads/2021/11/21/3.png" style="width: 476px; height: 100px;" />
|
|
<pre>
|
|
<strong>Input:</strong> fruits = [[0,3],[6,4],[8,5]], startPos = 3, k = 2
|
|
<strong>Output:</strong> 0
|
|
<strong>Explanation:</strong>
|
|
You can move at most k = 2 steps and cannot reach any position with fruits.
|
|
</pre>
|
|
|
|
<p> </p>
|
|
<p><strong>Constraints:</strong></p>
|
|
|
|
<ul>
|
|
<li><code>1 <= fruits.length <= 10<sup>5</sup></code></li>
|
|
<li><code>fruits[i].length == 2</code></li>
|
|
<li><code>0 <= startPos, position<sub>i</sub> <= 2 * 10<sup>5</sup></code></li>
|
|
<li><code>position<sub>i-1</sub> < position<sub>i</sub></code> for any <code>i > 0</code> (<strong>0-indexed</strong>)</li>
|
|
<li><code>1 <= amount<sub>i</sub> <= 10<sup>4</sup></code></li>
|
|
<li><code>0 <= k <= 2 * 10<sup>5</sup></code></li>
|
|
</ul>
|