Lv1. [2024 카카오 윈터 인턴쉽] 가장 많이 받은 선물

가장 많이 받은 선물

프로그래머스 문제

2024 카카오 윈터 인턴쉽 문제가 오픈되어 풀어보았다.

가장많이받은선물-1.png

문제 설명

  • 선물을 받은 사람과 선물을 준 사람이 있다.
  • 선물 기록을 토대로 가장 많이 선물을 받은 사람을 구하라

가장 많이 선물을 받은 사람을 반환해라

흐름 파악

흐름 파악을 위해 꼬리에 꼬리를 무는 방식으로 접근하려한다.

다음 달 선물을 받은 사람은 어떻게 구할 수 있을까?

A 와 B 가 있을 때 선물을 더 많이 준 사람이 선물을 받는다.

선물을 더 많이 준 사람은 어떻게 구할 수 있을까?

아래와 같은 자료구조로 만들어서 선물을 비교할 수 있다.

[A] : {
  [B]: 1,
  [C]: 2,
  [D]: 3
}

값 추출을 어떻게 해?

friends 를 기준으로 이중 for 문을 돌려서 값을 추출한다.

gift_index[a][b] 와 gift_index[b][a] 를 비교해서 값을 추출할 수 있다.

8자 그래프의 경우 간선이 2개 나올 경우 이른 리턴을 하면 된다.

from collections import defaultdict


def solution(friends, gifts):
    give_dict = {k: defaultdict(int) for k in friends}
    gift_index = defaultdict(int)

    for gift in gifts:
        a, b = gift.split(" ")
        give_dict[a][b] += 1

        gift_index[a] += 1
        gift_index[b] -= 1

    predict_dict = defaultdict(int)

    for a in friends:
        for b in [b for b in friends if a != b]:
            if give_dict[a][b] < give_dict[b][a]:
                continue

            if give_dict[a][b] == give_dict[b][a]:
                if gift_index[a] <= gift_index[b]:
                    continue

            predict_dict[a] += 1

    if not predict_dict.items():
        return 0

    return max([v for k, v in predict_dict.items()])


print(solution(["muzi", "ryan", "frodo", "neo"], [
    "muzi frodo", "muzi frodo", "ryan muzi", "ryan muzi", "ryan muzi", "frodo muzi", "frodo ryan", "neo muzi"]),
      2)

print(solution(["joy", "brad", "alessandro", "conan", "david"], [
    "alessandro brad", "alessandro joy", "alessandro conan", "david alessandro", "alessandro david"]), 4)
print(solution(["a", "b", "c"], ["a b", "b a", "c a", "a c", "a c", "c a"]), 0)

JS Lexical Scope

Lexical Scope

Lexical Scope 는 정적 스코프

Lv3. [2024 카카오 윈터 인턴쉽] 주사위 고르기

주사위 고르기

NCloud LB & SourcePipeline 구축하기
tech collection 서비스 성능 개선하기
Selenium 복권 구매 자동화 만들어보기
디자인 패턴
책 리뷰
블로그 챌린지