mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 06:48:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			59 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>There is an <code>n x n</code> grid, with the top-left cell at <code>(0, 0)</code> and the bottom-right cell at <code>(n - 1, n - 1)</code>. You are given the integer <code>n</code> and an integer array <code>startPos</code> where <code>startPos = [start<sub>row</sub>, start<sub>col</sub>]</code> indicates that a robot is initially at cell <code>(start<sub>row</sub>, start<sub>col</sub>)</code>.</p>
 | |
| 
 | |
| <p>You are also given a <strong>0-indexed</strong> string <code>s</code> of length <code>m</code> where <code>s[i]</code> is the <code>i<sup>th</sup></code> instruction for the robot: <code>'L'</code> (move left), <code>'R'</code> (move right), <code>'U'</code> (move up), and <code>'D'</code> (move down).</p>
 | |
| 
 | |
| <p>The robot can begin executing from any <code>i<sup>th</sup></code> instruction in <code>s</code>. It executes the instructions one by one towards the end of <code>s</code> but it stops if either of these conditions is met:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li>The next instruction will move the robot off the grid.</li>
 | |
| 	<li>There are no more instructions left to execute.</li>
 | |
| </ul>
 | |
| 
 | |
| <p>Return <em>an array</em> <code>answer</code> <em>of length</em> <code>m</code> <em>where</em> <code>answer[i]</code> <em>is <strong>the number of instructions</strong> the robot can execute if the robot <strong>begins executing from</strong> the</em> <code>i<sup>th</sup></code> <em>instruction in</em> <code>s</code>.</p>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Example 1:</strong></p>
 | |
| <img alt="" src="https://assets.leetcode.com/uploads/2021/12/09/1.png" style="width: 145px; height: 142px;" />
 | |
| <pre>
 | |
| <strong>Input:</strong> n = 3, startPos = [0,1], s = "RRDDLU"
 | |
| <strong>Output:</strong> [1,5,4,3,1,0]
 | |
| <strong>Explanation:</strong> Starting from startPos and beginning execution from the i<sup>th</sup> instruction:
 | |
| - 0<sup>th</sup>: "<u><strong>R</strong></u>RDDLU". Only one instruction "R" can be executed before it moves off the grid.
 | |
| - 1<sup>st</sup>:  "<u><strong>RDDLU</strong></u>". All five instructions can be executed while it stays in the grid and ends at (1, 1).
 | |
| - 2<sup>nd</sup>:   "<u><strong>DDLU</strong></u>". All four instructions can be executed while it stays in the grid and ends at (1, 0).
 | |
| - 3<sup>rd</sup>:    "<u><strong>DLU</strong></u>". All three instructions can be executed while it stays in the grid and ends at (0, 0).
 | |
| - 4<sup>th</sup>:     "<u><strong>L</strong></u>U". Only one instruction "L" can be executed before it moves off the grid.
 | |
| - 5<sup>th</sup>:      "U". If moving up, it would move off the grid.
 | |
| </pre>
 | |
| 
 | |
| <p><strong>Example 2:</strong></p>
 | |
| <img alt="" src="https://assets.leetcode.com/uploads/2021/12/09/2.png" style="width: 106px; height: 103px;" />
 | |
| <pre>
 | |
| <strong>Input:</strong> n = 2, startPos = [1,1], s = "LURD"
 | |
| <strong>Output:</strong> [4,1,0,0]
 | |
| <strong>Explanation:</strong>
 | |
| - 0<sup>th</sup>: "<u><strong>LURD</strong></u>".
 | |
| - 1<sup>st</sup>:  "<u><strong>U</strong></u>RD".
 | |
| - 2<sup>nd</sup>:   "RD".
 | |
| - 3<sup>rd</sup>:    "D".
 | |
| </pre>
 | |
| 
 | |
| <p><strong>Example 3:</strong></p>
 | |
| <img alt="" src="https://assets.leetcode.com/uploads/2021/12/09/3.png" style="width: 67px; height: 64px;" />
 | |
| <pre>
 | |
| <strong>Input:</strong> n = 1, startPos = [0,0], s = "LRUD"
 | |
| <strong>Output:</strong> [0,0,0,0]
 | |
| <strong>Explanation:</strong> No matter which instruction the robot begins execution from, it would move off the grid.
 | |
| </pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>m == s.length</code></li>
 | |
| 	<li><code>1 <= n, m <= 500</code></li>
 | |
| 	<li><code>startPos.length == 2</code></li>
 | |
| 	<li><code>0 <= start<sub>row</sub>, start<sub>col</sub> < n</code></li>
 | |
| 	<li><code>s</code> consists of <code>'L'</code>, <code>'R'</code>, <code>'U'</code>, and <code>'D'</code>.</li>
 | |
| </ul>
 |