[프로그래머스] 폰켓몬 javascript

[찾아라 프로그래밍 마에스터] level2 폰켓몬

javascript

조건
* 최대한 많은 종류의 폰켓몬을 포함해서 N/2마리를 선택
* 가장 많은 종류의 폰켓몬을 선택하는 방법을 찾아, 그때의 폰켓몬 종류 번호의 개수를 return

제한사항
  • nums는 폰켓몬의 종류 번호가 담긴 1차원 배열입니다.
  • nums의 길이(N)는 1 이상 10,000 이하의 자연수이며, 항상 짝수로 주어집니다.
  • 폰켓몬의 종류 번호는 1 이상 200,000 이하의 자연수로 나타냅니다.
  • 가장 많은 종류의 폰켓몬을 선택하는 방법이 여러 가지인 경우에도, 선택할 수 있는 폰켓몬 종류 개수의 최댓값 하나만 return 하면 됩니다.

입출력 예
numsresult
[3,1,2,3]2
[3,3,3,2,2,4]3
[3,3,3,2,2,2]2

코드
function solution(nums) {
    let max = nums.length / 2; //골라야하는 갯수
    
    //중복제거
    let stack = [];
    nums.concat().forEach(value => {
        if (stack.indexOf(value) === -1)
            stack.push(value)
    });
    
    return stack.length >= max ? max : stack.length;
}

댓글