코딩 테스트/Level 1
2024 KAKAO WINTER INTERNSHIP 가장 많이 받은 선물
컴닥
2024. 4. 3. 09:49
반응형
https://school.programmers.co.kr/learn/courses/30/lessons/258712
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
자료 구조까지 예시로 제공되어 풀기 쉽도록 만든 문제..
매번 friends에서 원소의 위치를 찾는 것은 비효율적이다.
딕셔너리(맵, 해시)를 이용해 O(1)로 위치를 찾도록 하자.
def solution(friends, gifts):
friend_index = {friend: index for index, friend in enumerate(friends)}
gift_table = [[0 for _ in friends] for _ in friends]
gift_factor = [0 for _ in friends]
results = [0 for _ in friends]
for _from, _to in map(lambda x: x.split(' '), gifts):
gift_table[friend_index[_from]][friend_index[_to]] += 1
gift_factor[friend_index[_from]] += 1
gift_factor[friend_index[_to]] -= 1
for i in range(len(friends)):
for j in range(len(friends)):
if gift_table[i][j] > gift_table[j][i]:
results[i] += 1
elif gift_table[i][j] == gift_table[j][i] and gift_factor[i] > gift_factor[j]:
results[i] += 1
return max(results)
map 대신 제너레이터 익스프레션을 사용해도 됨.
def solution(friends, gifts):
friend_index = {friend: index for index, friend in enumerate(friends)}
gift_table = [[0 for _ in friends] for _ in friends]
gift_factor = [0 for _ in friends]
results = [0 for _ in friends]
for _from, _to in (x.split(' ') for x in gifts):
gift_table[friend_index[_from]][friend_index[_to]] += 1
gift_factor[friend_index[_from]] += 1
gift_factor[friend_index[_to]] -= 1
for i in range(len(friends)):
for j in range(len(friends)):
if gift_table[i][j] > gift_table[j][i]:
results[i] += 1
elif gift_table[i][j] == gift_table[j][i] and gift_factor[i] > gift_factor[j]:
results[i] += 1
return max(results)
반응형