Algorithm Problem with JavaScript — 1 day
Problem
수많은 마라톤 선수들이 마라톤에 참여하였습니다. 단 한 명의 선수를 제외하고는 모든 선수가 마라톤을 완주하였습니다.
마라톤에 참여한 선수들의 이름이 담긴 배열 participant와 완주한 선수들의 이름이 담긴 배열 completion이 주어질 때, 완주하지 못한 선수의 이름을 return 하도록 solution 함수를 작성해주세요.
제한사항
- 마라톤 경기에 참여한 선수의 수는 1명 이상 100,000명 이하입니다.
- completion의 길이는 participant의 길이보다 1 작습니다.
- 참가자의 이름은 1개 이상 20개 이하의 알파벳 소문자로 이루어져 있습니다.
- 참가자 중에는 동명이인이 있을 수 있습니다.
입출력 예
1. 문제 이해하기
participant(참가자) 배열과 completion(완주자) 배열의 비교 해서 남는 배열 요소를 출력하면 될 것 같다. 하지만 참여한 선수의 수가 100,000명 이하로 주어진 것을 보아 시간 복잡도를 고려해야 할 것 같다. 2중으로 for 문을 돌리면 시간초과에 걸린다.
2. 해결 방법
participant(참가자) 배열과 completion(완주자) 배열 모두 sort()를 이용해서 정렬시키자. 그리고 인덱스 0부터 두 배열을 비교하면 for문 한 번으로 문제를 해결할 수 있다. participant(참가자) 배열과 completion(완주자) 배열을 0번 부터 비교하다보면 participant(참가자) 배열에 비완주자(정답)가 나올 경우 두 배열 비교 연산은 불일치가 나올 것이고 그 때 participant(참가자) 배열의 요소를 출력하면 된다.
3. 코드 구현
4. 결과 분석
실행결과
채점결과
5. 통과
정확성과 효율성 테스트 모두 통과하였습니다.
*자바스크립트 특이사항(c/c++과 다른 점)
- .sort()로 간단하게 정렬하기
- for문에서 int 대신 var 쓰기 (다음에는 for each 또는 for in문 사용해보기)
- 비교할 때 ‘==’ 대신 ‘===’ 사용하기
- 입력 받는 부분을 만들 필요가 없다(구현하기 어려워서?)
문제 출처