极客时间返利平台,你可以在上边通过山月的链接购买课程,并添加我的微信 (shanyue94) 领取返现。
山月训练营之面试直通车 服务上线了,从准备简历、八股文准备、项目经历准备、面试、面经、面经解答、主观问题答复、谈薪再到入职的一条龙服务。

# 实现一个函数 max,找到数组中最大的一个值/两个值/N 个值

Issue

欢迎在 Gtihub Issue 中回答此问题: Issue 647 (opens new window)

求最大的一个值:

function max(list) {
  if (!list.length) {
    return 0;
  }
  return list.reduce((x, y) => (x > y ? x : y));
}

求最大的两个值:

代码见 找出数组中最大的两个值 - codepen (opens new window)

function maxTwo(list) {
  let max = -Infinity,
    secondMax = -Infinity;
  for (const x of list) {
    if (x > max) {
      secondMax = max;
      max = x;
    } else if (x > secondMax) {
      secondMax = x;
    }
  }
  return [max, secondMax];
}

如果求 TopN,可使用大顶堆、小顶堆实现,见另一个问题

Author

回答者: Yu-Lxy (opens new window)

const maxTwo = (arr) => {
  const max = Math.max(...arr);
  const secondMax = Math.max(...arr.filter((a) => a !== max));
  return [max, secondMax];
};
Last Updated: 9/27/2022, 2:39:59 PM