코딩테스트

[프로그래머스/Javascript] 과일 장수

셈인 2023. 6. 22. 23:05

문제

https://school.programmers.co.kr/learn/courses/30/lessons/135808

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr


문제 접근

  • 사과 상자의 가격은 상자에 포함된 최저 사과 점수로 결정된다.
  • 포장되지 않은 사과는 버려진다.

👉 최대 이익을 구해야하기 때문에 낮은 점수의 사과를 버리는 방향으로 진행

👉 사과 점수를 내림차순으로 정리하고, 개수에 맞게 포장하여 가격을 구하자


문제 풀이

function solution(k, m, score) {
    const scoreToDesc = score.sort((a, b) => b - a);
    let sum = 0;

    for (let i = 0; i <= Math.floor(score.length / m) - 1; i++) {
        const box = scoreToDesc.slice(i * m, (i * m) + m);
        sum += Math.min(...box);
    }
        
    return sum * m;
}