코딩테스트/python
프로그래머스_python_다단계 칫솔 판매
zyin
2021. 12. 22. 04:23
문제
https://programmers.co.kr/learn/courses/30/lessons/77486
코딩테스트 연습 - 다단계 칫솔 판매
민호는 다단계 조직을 이용하여 칫솔을 판매하고 있습니다. 판매원이 칫솔을 판매하면 그 이익이 피라미드 조직을 타고 조금씩 분배되는 형태의 판매망입니다. 어느정도 판매가 이루어진 후,
programmers.co.kr
풀이
1. 서로소 집합 자료 구조 (Disjoint-set data structure)
tree 구조이므로 서로소 집합 자료 구조 (Disjoint-set data structure) 또는 Union-Find 알고리즘을 응용하여 사용한다.
2. 시간초과
case11, csae12, case13에서 시간초과가 발생했다. 남은 이익이 0이 될때 탐색을 멈추도록 하면 해결할 수 있었다. (다른 사람의 풀이를 보고 확인했다...)
더보기
시간초과 코드
def solution(enroll, referral, seller, amount):
parent = {c:p for c, p in zip(enroll, referral)} # 부모정보를 저장
ans = {c:0 for c in enroll} # 각 노드별 이익을 저장
for s, m in zip(seller, amount) :
m*=100 # 칫솔 한개당 100원
while s in parent :
ans[s] += m-int(m*0.1) # 노드에 이익저장하기
m = int(m*0.1) # 남은 금액 저장하기
s = parent[s] # 노드 갱신하기
return [ans[c] for c in enroll] # enroll 순서대로 이익금 리스트 만들기
코드
def solution(enroll, referral, seller, amount):
parent = {c:p for c, p in zip(enroll, referral)} # 부모정보를 저장
ans = {c:0 for c in enroll} # 각 노드별 이익을 저장
for s, m in zip(seller, amount) :
m*=100 # 칫솔 한개당 100원
while s in parent and m>0 :
ans[s] += m-int(m*0.1) # 노드에 이익저장하기
m = int(m*0.1) # 남은 금액 저장하기
s = parent[s] # 노드 갱신하기
return [ans[c] for c in enroll] # enroll 순서대로 이익금 리스트 만들기