LeetCode简单题之去掉最低工资和最高工资后的工资平均值
題目
給你一個整數數組 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 以內的結果都將視為正確答案。
來源:力扣(LeetCode)
解題思路
??非常簡單的一道題。
class Solution:def average(self, salary: List[int]) -> float:return (sum(salary)-max(salary)-min(salary))/(len(salary)-2)
??以上雖然時間復雜度是O(n)但可能已經掃描的好幾遍數組。可以一次掃描數組完成。
class Solution:def average(self, salary: List[int]) -> float:if salary[0]>salary[1]:MIN=salary[1]MAX=salary[0]else:MIN=salary[0]MAX=salary[1]s=MIN+MAXl=0for i in salary[2:]:if i>MAX:MAX=ielif i<MIN:MIN=il+=1s+=ireturn (s-MIN-MAX)/l
總結
以上是生活随笔為你收集整理的LeetCode简单题之去掉最低工资和最高工资后的工资平均值的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: LeetCode简单题之在既定时间做作业
- 下一篇: LeetCode简单题之判断能否形成等差