728x90
문제 설명
수많은 마라톤 선수들이 마라톤에 참여하였습니다. 단 한 명의 선수를 제외하고는 모든 선수가 마라톤을 완주하였습니다.
마라톤에 참여한 선수들의 이름이 담긴 배열 participant와 완주한 선수들의 이름이 담긴 배열 completion이 주어질 때, 완주하지 못한 선수의 이름을 return 하도록 solution 함수를 작성해주세요.
제한사항
- 마라톤 경기에 참여한 선수의 수는 1명 이상 100,000명 이하입니다.
- completion의 길이는 participant의 길이보다 1 작습니다.
- 참가자의 이름은 1개 이상 20개 이하의 알파벳 소문자로 이루어져 있습니다.
- 참가자 중에는 동명이인이 있을 수 있습니다.
풀이)
이거 전에 풀어본 기억이 있어서 그냥 간단하게 풀었다
해시 문젠데 해시로 풀지 않은 아이러니,,
def solution(participant, completion):
participant.sort()
completion.sort()
for i in range(len(completion)):
if(participant[i]!=completion[i]):
return participant[i];
return participant[-1]
입력 받은 리스트들을 정렬하고 비교한다
만약 같지 않다면 그 사람은 완주하지 못한거니까 반환하면 된다
그리고 participant의 마지막 원소는 무조건 완주하지 못한거니까 반환하면 된다
이건 전에 풀었던 c++ 코드
#include <string>
#include <vector>
#include <algorithm>
using namespace std;
string solution(vector<string> participant, vector<string> completion) {
string answer = "";
sort(participant.begin(), participant.end());
sort(completion.begin(), completion.end());
for(int i=0;i<participant.size();i++)
{
if(participant[i]!=completion[i])
return participant[i];
}
return answer;
}
해시로 다시 풀어보려다 음 너무 비효율적이라 포기!
그냥 해시 공부하고 레벨2부터 다시 해봐야겠당 'ㅅ'
728x90
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[해시] Level 2 전화번호 목록 (0) | 2021.12.24 |
---|---|
[해시] Level 2 위장 (0) | 2021.12.24 |
해시 > 완주하지 못한 선수 (0) | 2021.08.20 |
탐욕법(Greedy) > 구명보트 (0) | 2021.08.15 |
탐욕법(Greedy) > 큰 수 만들기 (0) | 2021.08.14 |
댓글