1491.去掉最低工资和最高工资后的工资平均值

【LetMeFly】1491.去掉最低工资和最高工资后的工资平均值:模拟(一次遍历)

力扣题目链接:https://leetcode.cn/problems/average-salary-excluding-the-minimum-and-maximum-salary/

给你一个整数数组 salary ,数组里每个数都是 唯一 的,其中 salary[i] 是第 i 个员工的工资。

请你返回去掉最低工资和最高工资以后,剩下员工工资的平均值。

 

示例 1:

输入:salary = [4000,3000,1000,2000]
输出:2500.00000
解释:最低工资和最高工资分别是 1000 和 4000 。
去掉最低工资和最高工资以后的平均工资是 (2000+3000)/2= 2500

示例 2:

输入:salary = [1000,2000,3000]
输出:2000.00000
解释:最低工资和最高工资分别是 1000 和 3000 。
去掉最低工资和最高工资以后的平均工资是 (2000)/1= 2000

示例 3:

输入:salary = [6000,5000,4000,3000,2000,1000]
输出:3500.00000

示例 4:

输入:salary = [8000,9000,2000,3000,6000,1000]
输出:4750.00000

 

提示:

  • 3 <= salary.length <= 100
  • 10^3 <= salary[i] <= 10^6
  • salary[i] 是唯一的。
  • 与真实值误差在 10^-5 以内的结果都将视为正确答案。

解题方法:一次遍历——使用数个变量记录

遍历给定数组,在遍历的过程中,使用三个变量分别记录数组中元素的最小值、最大值、总和。

遍历结束后,$\frac{总和-最小值-最大值}{数组长度-2}$即为答案。

  • 时间复杂度$O(len(salary))$
  • 空间复杂度$O(1)$

AC代码

C++

1
2
3
4
5
6
7
8
9
10
11
12
class Solution {
public:
double average(vector<int>& salary) {
int m = salary[0], M = m, s = 0;
for (int t : salary) {
m = min(m, t);
M = max(M, t);
s += t;
}
return (double)(s - m - M) / (salary.size() - 2);
}
};

Python

1
2
3
4
5
from typing import List

class Solution:
def average(self, salary: List[int]) -> float:
return (sum(salary) - min(salary) - max(salary)) / (len(salary) - 2)

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/138416153


1491.去掉最低工资和最高工资后的工资平均值
https://blog.letmefly.xyz/2024/05/03/LeetCode 1491.去掉最低工资和最高工资后的工资平均值/
作者
Tisfy
发布于
2024年5月3日
许可协议