1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-09-04 23:11:41 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee

存量题库数据更新

This commit is contained in:
2023-12-09 18:42:21 +08:00
parent a788808cd7
commit c198538f10
10843 changed files with 288489 additions and 248355 deletions

View File

@@ -1,39 +1,49 @@
<p>一个N x N的网格<code>(grid)</code>&nbsp;代表一块樱桃地,每个格子由以下三种数字的一种来表示:</p>
<p>给你一个 <code>n x n</code> 的网格 <code>grid</code> 代表一块樱桃地,每个格子由以下三种数字的一种来表示:</p>
<ul>
<li>0 表示这个格子是空的,所以你可以穿过它。</li>
<li>1 表示这个格子里装着一个樱桃,你可以摘到樱桃然后穿过它。</li>
<li>-1 表示这个格子里有荆棘,挡着你的路。</li>
<li><code>0</code> 表示这个格子是空的,所以你可以穿过它。</li>
<li><code>1</code> 表示这个格子里装着一个樱桃,你可以摘到樱桃然后穿过它。</li>
<li><code>-1</code> 表示这个格子里有荆棘,挡着你的路。</li>
</ul>
<p>你的任务是在遵守下列规则的情况下,尽可能的摘到最多樱桃:</p>
<p>请你统计并返回:在遵守下列规则的情况下,摘到最多樱桃</p>
<ul>
<li>从位置&nbsp;(0, 0) 出发,最后到达 (N-1, N-1) 只能向下或向右走并且只能穿越有效的格子即只可以穿过值为0或者1的格子);</li>
<li>当到达 (N-1, N-1) 后,你要继续走,直到返回到 (0, 0) ,只能向上或向左走,并且只能穿越有效的格子;</li>
<li>当你经过一个格子且这个格子包含一个樱桃时,你将摘到樱桃并且这个格子会变成空的(值变为0</li>
<li>如果在 (0, 0) 和 (N-1, N-1) 之间不存在一条可经过的路径,则没有任何一个樱桃能被摘到</li>
<li>从位置&nbsp;<code>(0, 0)</code> 出发,最后到达 <code>(n - 1, n - 1)</code> ,只能向下或向右走,并且只能穿越有效的格子(即只可以穿过值为 <code>0</code> 或者 <code>1</code> 的格子);</li>
<li>当到达 <code>(n - 1, n&nbsp;- 1)</code> 后,你要继续走,直到返回到 <code>(0, 0) </code>,只能向上或向左走,并且只能穿越有效的格子;</li>
<li>当你经过一个格子且这个格子包含一个樱桃时,你将摘到樱桃并且这个格子会变成空的(值变为 <code>0</code> </li>
<li>如果在 <code>(0, 0)</code><code>(n - 1, n - 1)</code> 之间不存在一条可经过的路径,则无法摘到任何一个樱桃。</li>
</ul>
<p><strong>示例 1:</strong></p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<img alt="" src="https://assets.leetcode.com/uploads/2020/12/14/grid.jpg" />
<pre>
<strong>输入:</strong> grid =
[[0, 1, -1],
[1, 0, -1],
[1, 1, 1]]
<strong>输出:</strong> 5
<strong>解释:</strong>
玩家从0,0点出发经过了向下走向下走向右走向右走到达了点(2, 2)。
在这趟单程中总共摘到了4颗樱桃矩阵变成了[[0,1,-1],[0,0,-1],[0,0,0]]。
接着这名玩家向左走向上走向上走向左走返回了起始点又摘到了1颗樱桃。
在旅程中总共摘到了5颗樱桃这是可以摘到的最大值了。
<b>输入</b>grid = [[0,1,-1],[1,0,-1],[1,1,1]]
<b>输出:</b>5
<b>解释:</b>玩家从 (0, 0) 出发:向下、向下、向右、向右移动至 (2, 2) 。
在这一次行程中捡到 4 个樱桃,矩阵变成 [[0,1,-1],[0,0,-1],[0,0,0]] 。
然后,玩家向左、向上、向上、向左返回起点,再捡到 1 个樱桃。
总共捡到 5 个樱桃,这是最大可能值。
</pre>
<p><strong>说明:</strong></p>
<p><strong>示例 2</strong></p>
<pre>
<b>输入:</b>grid = [[1,1,-1],[1,-1,1],[-1,1,1]]
<b>输出:</b>0
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>grid</code> 是一个&nbsp;<code>N</code> * <code>N</code> 的二维数组N的取值范围是<code>1 &lt;= N &lt;= 50</code></li>
<li>每一个&nbsp;<code>grid[i][j]</code> 都是集合&nbsp;<code>{-1, 0, 1}</code>其中的一个数。</li>
<li>可以保证起点&nbsp;<code>grid[0][0]</code>&nbsp;和终点&nbsp;<code>grid[N-1][N-1]</code>&nbsp;的值都不会是 -1。</li>
<li><code>n == grid.length</code></li>
<li><code>n == grid[i].length</code></li>
<li><code>1 &lt;= n &lt;= 50</code></li>
<li><code>grid[i][j]</code>&nbsp;&nbsp;<code>-1</code><code>0</code>&nbsp;&nbsp;<code>1</code></li>
<li><code>grid[0][0] != -1</code></li>
<li><code>grid[n - 1][n - 1] != -1</code></li>
</ul>