다단계 칫솔 판매 (트리, 리스트 인덱스, 딕셔너리, 재귀)

2023. 8. 7. 16:13·Coding Test/programmers
728x90

https://school.programmers.co.kr/learn/courses/30/lessons/77486

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

분석

 판매원에게 배분된 이익금의 총합을 계산하여(정수형으로), 입력으로 주어진 enroll에 이름이 포함된 순서에 따라 나열

seller, amount에 따른 이익이 날때마다 배분금액 계산 후 잔여량 수익금에 저장

 

풀이

1. 리스트 인덱스 딕셔너리 저장

def solution(enroll, referral, seller, amount):
    
    money = [0 for _ in range(len(enroll))]
    dict = {}
    for i, e in enumerate(enroll):
        dict[e] = i
        
    for s, a in zip(seller, amount):
        m = a * 100 # 이익금
        while s != "-" and m>0:
            idx = dict[s]
            money[idx] += m-m//10 # 수익 저장
            m //= 10 # 배분
            s = referral[idx] # 상위로 이동
    return money

 

2. 재귀

def solution(enroll, referral, seller, amount):

    parent = dict(zip(enroll, referral))
    answer = dict(zip(enroll, [0]*len(enroll)))

    def distribute(target, money):
        if  money<10:
            answer[target]+=money
        elif parent[target]=='-':
            answer[target]+=money-money//10
        else:
            answer[target]+=money-money//10 # 수익
            distribute(parent[target], money//10) # 분배

    for s,t in zip(seller, amount):
        distribute(s, t*100) # 이익금

    return list(answer.values())
728x90
저작자표시 비영리 변경금지 (새창열림)
'Coding Test/programmers' 카테고리의 다른 글
  • 디펜스 게임 (우선순위큐, 힙)
  • 리코쳇 로봇 (BFS)
  • 110 옮기기 (스택)
  • 풍선 터트리기 (스택, 최솟값 비교, memoization)
Karla Ko
Karla Ko
𝘾𝙤𝙣𝙩𝙞𝙣𝙪𝙤𝙪𝙨𝙡𝙮 𝙄𝙢𝙥𝙧𝙤𝙫𝙞𝙣𝙜, 𝘾𝙤𝙣𝙨𝙩𝙖𝙣𝙩𝙡𝙮 𝘿𝙚𝙫𝙚𝙡𝙤𝙥𝙞𝙣𝙜 𝙔𝙚𝙨!
    250x250
  • Karla Ko
    karlaLog
    Karla Ko
  • 전체
    오늘
    어제
    • Total (467)
      • Spring (19)
      • JPA (4)
      • Cloud & Architecture (15)
        • Kubernetes (5)
        • Docker (3)
        • MSA (2)
        • GCP (1)
        • AWS (4)
      • Devops (1)
      • Message Queue (4)
        • Kafka (2)
        • RabbitMQ (2)
      • Git (4)
      • DB (4)
      • Java (9)
      • Python (4)
      • CS (11)
        • OS (8)
        • Network (2)
        • Algorithm (1)
      • Coding Test (392)
        • programmers (156)
        • Graph (43)
        • DP (37)
        • Search (31)
        • Tree (13)
        • Data Structure (26)
        • Combination (12)
        • Implement (18)
        • Geedy (23)
        • Sort (7)
        • Math (21)
        • geometry (2)
  • 블로그 메뉴

    • 홈
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    스택
    덱
    백준
    파이썬
    최단거리
    알고리즘
    최소신장트리
    다익스트라
    동적계획법
    구간합
    자료구조
    구현
    DP
    큐
    월간코드챌린지
    조합
    정렬
    재귀
    플로이드워셜
    이분탐색
    프로그래머스
    BFS
    DFS
    힙
    트리
    최대공약수
    LIS
    Algorithm
    그리디
    그래프
  • hELLO· Designed By정상우.v4.10.3
Karla Ko
다단계 칫솔 판매 (트리, 리스트 인덱스, 딕셔너리, 재귀)
상단으로

티스토리툴바