728x90
문제 설명
수많은 마라톤 선수들이 마라톤에 참여하였습니다. 단 한 명의 선수를 제외하고는 모든 선수가 마라톤을
완주하였습니다.
마라톤에 참여한 선수들의 이름이 담긴 배열 pariticpant와 완주한 선수들의 이름이 담긴 배열 completion이 주어질 때,
완주하지 못한 선수의 이름을 return 하도록 solution 함수를 작성해 주세요
제한사항
- 마라톤 경기에 참여한 선수의 수는 1명 이상 100,000명 이하입니다.
- completion의 길이는 participant의 길이보다 1 작습니다.
- 참가자의 이름은 1개 이상 20개 이하의 알파벳 소문자로 이루어져 있습니다.
- 참가자 중에는 동명이인이 있을 수 있습니다.
입출력 예
pariticipant | completion | return |
["leo", "kiki", "eden"] | ["eden", "kiki"] | "leo" |
["marina", "josipa", "nikola", "vinko", "filipa"] | ["josipa", "filipa", "marina", "nikola"] | "vinko" |
["mislav", "stanko", "mislav", "ana"] | ["stanko","ana", "misiav"] | "misav" |
문제 풀이
- 문제이해하기
participant(참가자) 배열과 completion(완주자) 배열 모두 sort() 정렬함수를 이용해서 정렬시켜준다.
그리고 index 0 부터 두 배열을 비교하면 for문 한번으로 문제를 해결해 줄 수 있다.
participant(참가자) 배열과 completion(완주자) 배열을 0번부터 비교하다보면 participant(참가자)배열에
비완주자(정답)이 나올 경우 두 배열 비교 연산은 불일치가 나올 것이고 그 때 participant(참가자) 배열의
요소를 출력하면 된다.
function solution(participant, completion) {
participant.sort() // 먼저 participant 이름이 담긴 선수들을 sort 함수로 배열을 정렬 시켜준다.
completion.sort() // 완주자도 동일하게 배열 정렬
// for문을 돌아
for(let i=0;i < participant.length;i++) {
if (participant[i] !== completion[i]) {
// index 0부터 순차적으로 두배열을 비교
return participant[i];
// 비완주자 참가자 배열이 나온다면 출력
}
}
}
실행결과
자바스크립트의 특이사항 (c/c++과 다른점)
- .sort()로 간단하게 정렬하기
- for문에서 int 대신 let 사용
- 비교연산자를 사용할때 '==' 대신 '===' 사용
- 입력 받는 부분을 만들 필요는 없다.
참고 자료
'etc. > Algorithm' 카테고리의 다른 글
[알고리즘 테스트] 위장 (0) | 2022.01.13 |
---|---|
[알고리즘 테스트] 부족한 금액 계산하기 (0) | 2022.01.13 |
[알고리즘 테스트] 숫자 문자열과 영단어 (0) | 2022.01.13 |