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)/网格图中机器人回家的最小代价 [minimum-cost-homecoming-of-a-robot-in-a-grid].html
2022-03-29 12:43:11 +08:00

49 lines
3.2 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<p>给你一个&nbsp;<code>m x n</code>&nbsp;的网格图,其中&nbsp;<code>(0, 0)</code>&nbsp;是最左上角的格子,<code>(m - 1, n - 1)</code>&nbsp;是最右下角的格子。给你一个整数数组&nbsp;<code>startPos</code>&nbsp;<code>startPos = [start<sub>row</sub>, start<sub>col</sub>]</code>&nbsp;表示 <strong>初始</strong>&nbsp;有一个 <strong>机器人</strong>&nbsp;在格子&nbsp;<code>(start<sub>row</sub>, start<sub>col</sub>)</code>&nbsp;处。同时给你一个整数数组&nbsp;<code>homePos</code>&nbsp;<code>homePos = [home<sub>row</sub>, home<sub>col</sub>]</code>&nbsp;表示机器人的 <strong></strong>&nbsp;在格子&nbsp;<code>(home<sub>row</sub>, home<sub>col</sub>)</code>&nbsp;处。</p>
<p>机器人需要回家。每一步它可以往四个方向移动:<strong></strong><strong></strong><strong></strong><strong></strong>,同时机器人不能移出边界。每一步移动都有一定代价。再给你两个下标从&nbsp;<strong>0</strong>&nbsp;开始的额整数数组:长度为&nbsp;<code>m</code>&nbsp;的数组&nbsp;<code>rowCosts</code> &nbsp;和长度为 <code>n</code>&nbsp;的数组&nbsp;<code>colCosts</code>&nbsp;</p>
<ul>
<li>如果机器人往 <strong></strong>&nbsp;或者往 <strong></strong>&nbsp;移动到第 <code>r</code>&nbsp;<strong></strong>&nbsp;的格子,那么代价为&nbsp;<code>rowCosts[r]</code>&nbsp;</li>
<li>如果机器人往 <strong></strong>&nbsp;或者往 <strong></strong>&nbsp;移动到第 <code>c</code>&nbsp;<strong></strong> 的格子,那么代价为&nbsp;<code>colCosts[c]</code>&nbsp;</li>
</ul>
<p>请你返回机器人回家需要的 <strong>最小总代价</strong>&nbsp;</p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<p><img alt="" src="https://assets.leetcode.com/uploads/2021/10/11/eg-1.png" style="width: 282px; height: 217px;"></p>
<pre><strong>输入:</strong>startPos = [1, 0], homePos = [2, 3], rowCosts = [5, 4, 3], colCosts = [8, 2, 6, 7]
<b>输出:</b>18
<b>解释:</b>一个最优路径为:
从 (1, 0) 开始
-&gt; 往下走到 (<em><strong>2</strong></em>, 0) 。代价为 rowCosts[2] = 3 。
-&gt; 往右走到 (2, <em><strong>1</strong></em>) 。代价为 colCosts[1] = 2 。
-&gt; 往右走到 (2, <em><strong>2</strong></em>) 。代价为 colCosts[2] = 6 。
-&gt; 往右走到 (2, <em><strong>3</strong></em>) 。代价为 colCosts[3] = 7 。
总代价为 3 + 2 + 6 + 7 = 18</pre>
<p><strong>示例 2</strong></p>
<pre><b>输入:</b>startPos = [0, 0], homePos = [0, 0], rowCosts = [5], colCosts = [26]
<b>输出:</b>0
<b>解释:</b>机器人已经在家了,所以不需要移动。总代价为 0 。
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>m == rowCosts.length</code></li>
<li><code>n == colCosts.length</code></li>
<li><code>1 &lt;= m, n &lt;= 10<sup>5</sup></code></li>
<li><code>0 &lt;= rowCosts[r], colCosts[c] &lt;= 10<sup>4</sup></code></li>
<li><code>startPos.length == 2</code></li>
<li><code>homePos.length == 2</code></li>
<li><code>0 &lt;= start<sub>row</sub>, home<sub>row</sub> &lt; m</code></li>
<li><code>0 &lt;= start<sub>col</sub>, home<sub>col</sub> &lt; n</code></li>
</ul>