mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-11 02:58:13 +08:00
50 lines
2.3 KiB
HTML
50 lines
2.3 KiB
HTML
|
<p>You are given a <strong>0-indexed</strong> array of non-negative integers <code>nums</code>. For each integer in <code>nums</code>, you must find its respective <strong>second greater</strong> integer.</p>
|
||
|
|
||
|
<p>The <strong>second greater</strong> integer of <code>nums[i]</code> is <code>nums[j]</code> such that:</p>
|
||
|
|
||
|
<ul>
|
||
|
<li><code>j > i</code></li>
|
||
|
<li><code>nums[j] > nums[i]</code></li>
|
||
|
<li>There exists <strong>exactly one</strong> index <code>k</code> such that <code>nums[k] > nums[i]</code> and <code>i < k < j</code>.</li>
|
||
|
</ul>
|
||
|
|
||
|
<p>If there is no such <code>nums[j]</code>, the second greater integer is considered to be <code>-1</code>.</p>
|
||
|
|
||
|
<ul>
|
||
|
<li>For example, in the array <code>[1, 2, 4, 3]</code>, the second greater integer of <code>1</code> is <code>4</code>, <code>2</code> is <code>3</code>, and that of <code>3</code> and <code>4</code> is <code>-1</code>.</li>
|
||
|
</ul>
|
||
|
|
||
|
<p>Return<em> an integer array </em><code>answer</code><em>, where </em><code>answer[i]</code><em> is the second greater integer of </em><code>nums[i]</code><em>.</em></p>
|
||
|
|
||
|
<p> </p>
|
||
|
<p><strong class="example">Example 1:</strong></p>
|
||
|
|
||
|
<pre>
|
||
|
<strong>Input:</strong> nums = [2,4,0,9,6]
|
||
|
<strong>Output:</strong> [9,6,6,-1,-1]
|
||
|
<strong>Explanation:</strong>
|
||
|
0th index: 4 is the first integer greater than 2, and 9 is the second integer greater than 2, to the right of 2.
|
||
|
1st index: 9 is the first, and 6 is the second integer greater than 4, to the right of 4.
|
||
|
2nd index: 9 is the first, and 6 is the second integer greater than 0, to the right of 0.
|
||
|
3rd index: There is no integer greater than 9 to its right, so the second greater integer is considered to be -1.
|
||
|
4th index: There is no integer greater than 6 to its right, so the second greater integer is considered to be -1.
|
||
|
Thus, we return [9,6,6,-1,-1].
|
||
|
</pre>
|
||
|
|
||
|
<p><strong class="example">Example 2:</strong></p>
|
||
|
|
||
|
<pre>
|
||
|
<strong>Input:</strong> nums = [3,3]
|
||
|
<strong>Output:</strong> [-1,-1]
|
||
|
<strong>Explanation:</strong>
|
||
|
We return [-1,-1] since neither integer has any integer greater than it.
|
||
|
</pre>
|
||
|
|
||
|
<p> </p>
|
||
|
<p><strong>Constraints:</strong></p>
|
||
|
|
||
|
<ul>
|
||
|
<li><code>1 <= nums.length <= 10<sup>5</sup></code></li>
|
||
|
<li><code>0 <= nums[i] <= 10<sup>9</sup></code></li>
|
||
|
</ul>
|