comments | difficulty | edit_url | rating | source | tags | |||
---|---|---|---|---|---|---|---|---|
true |
Easy |
1201 |
Weekly Contest 277 Q1 |
|
Given an integer array nums
, return the number of elements that have both a strictly smaller and a strictly greater element appear in nums
.
Example 1:
Input: nums = [11,7,2,15]
Output: 2
Explanation: The element 7 has the element 2 strictly smaller than it and the element 11 strictly greater than it.
Element 11 has element 7 strictly smaller than it and element 15 strictly greater than it.
In total there are 2 elements having both a strictly smaller and a strictly greater element appear in nums
.
Example 2:
Input: nums = [-3,3,3,90]
Output: 2
Explanation: The element 3 has the element -3 strictly smaller than it and the element 90 strictly greater than it.
Since there are two elements with the value 3, in total there are 2 elements having both a strictly smaller and a strictly greater element appear in nums
.
Constraints:
1 <= nums.length <= 100
-105 <= nums[i] <= 105
According to the problem description, we can first find the minimum value
The time complexity is
class Solution:
def countElements(self, nums: List[int]) -> int:
mi, mx = min(nums), max(nums)
return sum(mi < x < mx for x in nums)
class Solution {
public int countElements(int[] nums) {
int mi = Arrays.stream(nums).min().getAsInt();
int mx = Arrays.stream(nums).max().getAsInt();
int ans = 0;
for (int x : nums) {
if (mi < x && x < mx) {
ans++;
}
}
return ans;
}
}
class Solution {
public:
int countElements(vector<int>& nums) {
auto [mi, mx] = ranges::minmax_element(nums);
return ranges::count_if(nums, [mi, mx](int x) { return *mi < x && x < *mx; });
}
};
func countElements(nums []int) (ans int) {
mi := slices.Min(nums)
mx := slices.Max(nums)
for _, x := range nums {
if mi < x && x < mx {
ans++
}
}
return
}
function countElements(nums: number[]): number {
const mi = Math.min(...nums);
const mx = Math.max(...nums);
return nums.filter(x => mi < x && x < mx).length;
}