Programming/Etc

[프로그래머스 문제 풀이] 코딩테스트 연습 > 해시 > 완주하지 못한 선수

통통만두 2018. 10. 15. 19:20
반응형

해당 문제와 채점 결과는 프로그래머스 사이트에 있는 내용이며 제가 작성한 부분은 프로그래머스 문제 풀이 입니다.


문제 설명

수많은 마라톤 선수들이 마라톤에 참여하였습니다. 단 한 명의 선수를 제외하고는 모든 선수가 마라톤을 완주하였습니다. 마라톤에 참여한 선수들의 이름이 담긴 배열 participant와 완주한 선수들의 이름이 담긴 배열 completion이 주어질 때, 완주하지 못한 선수의 이름을 return 하도록 solution 함수를 작성해주세요.


제한사항

  • 마라톤 경기에 참여한 선수의 수는 1명 이상 100,000명 이하입니다.
  • completion의 길이는 participant의 길이보다 1 작습니다.
  • 참가자의 이름은 1개 이상 20개 이하의 알파벳 소문자로 이루어져 있습니다.
  • 참가자 중에는 동명이인이 있을 수 있습니다.

입출력 예

participant

completion 

return 

 ["leo", "kiki", "eden"]

 ["eden", "kiki"]

 "leo"

 ["marina", "josipa", "nikola", "vinko", "filipa"]

 ["josipa", "filipa", "marina", "nikola"]

 "vinko"

 ["mislav", "stanko", "mislav", "ana"]

 ["stanko", "ana", "mislav"]

 "mislav"


입출력 예 설명

예제 #1
"leo"는 참여자 명단에는 있지만, 완주자 명단에는 없기 때문에 완주하지 못했습니다.

예제 #2
"vinko"는 참여자 명단에는 있지만, 완주자 명단에는 없기 때문에 완주하지 못했습니다.

예제 #3
"mislav"는 참여자 명단에는 두 명이 있지만, 완주자 명단에는 한 명밖에 없기 때문에 한 명은 완주하지 못했습니다.

제출한 코드 #1

function solution(participant, completion) {
    var answer = '';
    
    for(var i = 0, iLen = completion.length; i < iLen; i++) {
        var index = participant.indexOf(completion[i]);
        if(index >= 0) {
            participant.splice(index, 1);
        }
    }
    
    return participant[0];
}

완주자 배열(completion)의 길이는 참가자 배열(participant)의 길이보다 1작다고 했기에 완주자 배열을 for문으로 돌면서 하나하나씩 참가자 배열에서 제거하면서 마지막 남은 참가자가 완주하지 못한 선수입니다. 그래서 Array.indexOf() 로 해당 인덱스를 구한 다음에 Array.splice() 로 참가자 배열에서 완주자를 1명씩 제거했습니다. 하지만 효율성을 따지만 그리 좋은 코드는 아니었나봅니다.


채점 결과 #1

헐킈! 정확성 테스트는 모두 통과하였으나 효율성 테스트는 꽝이네요 ㅋㅋㅋ 효율성까지 보는지는 모르고 배열이니깐 참가자 배열에서 완주자 배열의 요소가 있으면 지우고 마지막 남는 1개를 정답으로 하는 것으로 했더니만 이런 결과를 가져왔네요. 마음을 가다듬고 다시 한 번 코드를 작성하고 채점을 해보도록 하겠습니다.


제출한 코드 #2

function solution(participant, completion) {
    participant.sort();
    completion.sort();
    
    for(var i = 0, iLen = participant.length; i < iLen; i++) {
        if(participant[i] !== completion[i])
            return participant[i];
    }
    
    return null;
}

function 의 처음 두 줄에 보이는 sort() 는 자바 스크립트(Java Script)의 표준 내장 객체 Array의 프로토타입(Prototype) 함수입니다. sort() 함수는 배열의 요소를 적절한 위치에 정렬한 후 그 배열을 반환합니다. 매개변수로 function을 넘길 수 있으며 매개변수로 별도의 function을 넘기지 않는다면 기본 정렬 순서는 문자열의 유니코드 코드 포인트를 따릅니다.

완주자의 길이는 참가자의 길이보다 1이 작다고 했으니 참가자와 완주자의 배열을 정렬한 다음 for문을 돌면서 n번째 인덱스의 배열의 요소가 틀린 것이 정답입니다.


채점 결과 #2


출처


반응형