mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 23:08:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			50 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>A newly designed keypad was tested, where a tester pressed a sequence of <code>n</code> keys, one at a time.</p>
 | |
| 
 | |
| <p>You are given a string <code>keysPressed</code> of length <code>n</code>, where <code>keysPressed[i]</code> was the <code>i<sup>th</sup></code> key pressed in the testing sequence, and a sorted list <code>releaseTimes</code>, where <code>releaseTimes[i]</code> was the time the <code>i<sup>th</sup></code> key was released. Both arrays are <strong>0-indexed</strong>. The <code>0<sup>th</sup></code> key was pressed at the time <code>0</code>, and every subsequent key was pressed at the <strong>exact</strong> time the previous key was released.</p>
 | |
| 
 | |
| <p>The tester wants to know the key of the keypress that had the <strong>longest duration</strong>. The <code>i<sup>th</sup></code><sup> </sup>keypress had a <strong>duration</strong> of <code>releaseTimes[i] - releaseTimes[i - 1]</code>, and the <code>0<sup>th</sup></code> keypress had a duration of <code>releaseTimes[0]</code>.</p>
 | |
| 
 | |
| <p>Note that the same key could have been pressed multiple times during the test, and these multiple presses of the same key <strong>may not</strong> have had the same <strong>duration</strong>.</p>
 | |
| 
 | |
| <p><em>Return the key of the keypress that had the <strong>longest duration</strong>. If there are multiple such keypresses, return the lexicographically largest key of the keypresses.</em></p>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong class="example">Example 1:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> releaseTimes = [9,29,49,50], keysPressed = "cbcd"
 | |
| <strong>Output:</strong> "c"
 | |
| <strong>Explanation:</strong> The keypresses were as follows:
 | |
| Keypress for 'c' had a duration of 9 (pressed at time 0 and released at time 9).
 | |
| Keypress for 'b' had a duration of 29 - 9 = 20 (pressed at time 9 right after the release of the previous character and released at time 29).
 | |
| Keypress for 'c' had a duration of 49 - 29 = 20 (pressed at time 29 right after the release of the previous character and released at time 49).
 | |
| Keypress for 'd' had a duration of 50 - 49 = 1 (pressed at time 49 right after the release of the previous character and released at time 50).
 | |
| The longest of these was the keypress for 'b' and the second keypress for 'c', both with duration 20.
 | |
| 'c' is lexicographically larger than 'b', so the answer is 'c'.
 | |
| </pre>
 | |
| 
 | |
| <p><strong class="example">Example 2:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> releaseTimes = [12,23,36,46,62], keysPressed = "spuda"
 | |
| <strong>Output:</strong> "a"
 | |
| <strong>Explanation:</strong> The keypresses were as follows:
 | |
| Keypress for 's' had a duration of 12.
 | |
| Keypress for 'p' had a duration of 23 - 12 = 11.
 | |
| Keypress for 'u' had a duration of 36 - 23 = 13.
 | |
| Keypress for 'd' had a duration of 46 - 36 = 10.
 | |
| Keypress for 'a' had a duration of 62 - 46 = 16.
 | |
| The longest of these was the keypress for 'a' with duration 16.</pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>releaseTimes.length == n</code></li>
 | |
| 	<li><code>keysPressed.length == n</code></li>
 | |
| 	<li><code>2 <= n <= 1000</code></li>
 | |
| 	<li><code>1 <= releaseTimes[i] <= 10<sup>9</sup></code></li>
 | |
| 	<li><code>releaseTimes[i] < releaseTimes[i+1]</code></li>
 | |
| 	<li><code>keysPressed</code> contains only lowercase English letters.</li>
 | |
| </ul>
 |