LC 2733.Neither Minimum nor Maximum
题目描述
这是 LeetCode
上的 2733.
既不是最小值也不是最大值 ,难度为简单。
给你一个整数数组 nums
,数组由
不同正整数 组成,请你找出并返回数组中
任一 既不是 最小值 也不是
最大值 的数字,如果不存在这样的数字,返回
-1
。
返回所选整数。
示例 1:
1 |
|
示例 2:
1 |
|
示例 3:
1 |
|
提示:
1 <= nums.length <= 100
1 <= nums[i] <= 100
nums
中的所有数字互不相同
解答
方法一:原地交换
由于数组中的整数都不相同,所以可以把最小值放在第一个位置,最大值放在最后一个位置,最后取第二个位置的值即可。如果题目中的整数允许存在相同的数,沿用相同的思路,使用两个指针,分别指向第一个位置和最后一个位置,遇到相同的数就移动指针,如果遇到不同的数就将指针返回起点。
1 |
|
时间复杂度:\(O(n)\),其中
n
是数组nums
的长度。空间复杂度:\(O(1)\)。
方法二:前三个元素排序
由于既不是最大值也不是最小值,并且整数互不相同,所以可以直接排序前三个数,取中间的数。
1 |
|
时间复杂度:\(O(1)\)。
空间复杂度:\(O(1)\)。
每题一图
LC 2733.Neither Minimum nor Maximum
https://chen-huaneng.github.io/2023/12/11/2023-12-11-2023-12-11-lc-2733/