mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 23:08:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			53 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>You and a gang of thieves are planning on robbing a bank. You are given a <strong>0-indexed</strong> integer array <code>security</code>, where <code>security[i]</code> is the number of guards on duty on the <code>i<sup>th</sup></code> day. The days are numbered starting from <code>0</code>. You are also given an integer <code>time</code>.</p>
 | |
| 
 | |
| <p>The <code>i<sup>th</sup></code> day is a good day to rob the bank if:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li>There are at least <code>time</code> days before and after the <code>i<sup>th</sup></code> day,</li>
 | |
| 	<li>The number of guards at the bank for the <code>time</code> days <strong>before</strong> <code>i</code> are <strong>non-increasing</strong>, and</li>
 | |
| 	<li>The number of guards at the bank for the <code>time</code> days <strong>after</strong> <code>i</code> are <strong>non-decreasing</strong>.</li>
 | |
| </ul>
 | |
| 
 | |
| <p>More formally, this means day <code>i</code> is a good day to rob the bank if and only if <code>security[i - time] >= security[i - time + 1] >= ... >= security[i] <= ... <= security[i + time - 1] <= security[i + time]</code>.</p>
 | |
| 
 | |
| <p>Return <em>a list of <strong>all</strong> days <strong>(0-indexed) </strong>that are good days to rob the bank</em>.<em> The order that the days are returned in does<strong> </strong><strong>not</strong> matter.</em></p>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong class="example">Example 1:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> security = [5,3,3,3,5,6,2], time = 2
 | |
| <strong>Output:</strong> [2,3]
 | |
| <strong>Explanation:</strong>
 | |
| On day 2, we have security[0] >= security[1] >= security[2] <= security[3] <= security[4].
 | |
| On day 3, we have security[1] >= security[2] >= security[3] <= security[4] <= security[5].
 | |
| No other days satisfy this condition, so days 2 and 3 are the only good days to rob the bank.
 | |
| </pre>
 | |
| 
 | |
| <p><strong class="example">Example 2:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> security = [1,1,1,1,1], time = 0
 | |
| <strong>Output:</strong> [0,1,2,3,4]
 | |
| <strong>Explanation:</strong>
 | |
| Since time equals 0, every day is a good day to rob the bank, so return every day.
 | |
| </pre>
 | |
| 
 | |
| <p><strong class="example">Example 3:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> security = [1,2,3,4,5,6], time = 2
 | |
| <strong>Output:</strong> []
 | |
| <strong>Explanation:</strong>
 | |
| No day has 2 days before it that have a non-increasing number of guards.
 | |
| Thus, no day is a good day to rob the bank, so return an empty list.
 | |
| </pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>1 <= security.length <= 10<sup>5</sup></code></li>
 | |
| 	<li><code>0 <= security[i], time <= 10<sup>5</sup></code></li>
 | |
| </ul>
 |