likes
comments
collection
share

夯实算法-去掉最低工资和最高工资后的工资平均值

作者站长头像
站长
· 阅读数 46

题目: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
  • 103 <=salary[i]<=10610^3 <= salary[i] <= 10^6103 <=salary[i]<=106
  • salary[i] 是唯一的。
  • 与真实值误差在 10−510^-5105 以内的结果都将视为正确答案。

解题思路

解法一

  • ①:先排序
  • ②:遍历时从第二个元素开始,倒数第二个元素结束,即排除了最小值和最大值,遍历过程中进行累加
  • ③:累加的结果除以元素总个数-2

解法二

将数组排序,调用sort方法,然后记录去除最小和最大值得个数,然后将剩余的人工资进行累加 最后进行求平均值。

代码实现

解法一

public double average(int[] salary) {
   Arrays.sort(salary);
   double sum = 0;
   for(int i = 1; i < (salary.length - 1 ); i++){
    sum += salary[i];
   }
   return sum/(salary.length - 2);
}

解法二

public double average(int[] salary) {
     Arrays.sort(salary);
     int count=salary.length-2;
     int b=0;
     for(int i=1;i<salary.length-1;i++){
       b+=salary[i];
     }
    return b/(double)count;
}

复杂度分析

  • 空间复杂度:O(1)O(1)O(1)
  • 时间复杂度:O(N)O(N)O(N)
转载自:https://juejin.cn/post/7171820020555579423
评论
请登录