일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 다익스트라
- KAKAO BLIND RECRUITMENT
- 그리디
- Zip
- dfs
- programmers
- java
- python
- divmod
- backjoon
- 백준
- 정렬
- BFS
- 수학
- 프로그래머스
- heapq
- Combinations
- 추석맞이 코딩챌린지
- 위클리 챌린지
- 자바
- 재귀함수
- 파이썬
- Set
- Re
- 동적 계획법
- DateTime
- 이분탐색
- lambda
- 카카오
- 정규식
Archives
- Today
- Total
상상쓰
[프로그래머스] 메뉴 리뉴얼 본문
https://programmers.co.kr/learn/courses/30/lessons/72411
이 문제를 처음 풀었을 때 문제 이해를 잘 못해서 시간이 조금 걸렸었다.
쉽게 말하면 정해진 개수로 단품 요리를 만들었을 때 가장 많이 주문된 조합을 구하면 된다.
combinations 을 활용하여 정해진 개수에 대해 조합을 구하여 menuList 에 담고 Counter 를 활용하여 조합된 요리가 몇 번 나왔는지 확인한다.
입출력 예제에서 정해진 개수가 2일 때,
menuList = [('AC', 4), ('CD', 3), ('CE', 3), ('DE', 3), ('BC', 2), ('BF', 2), ('BG', 2), ('CF', 2), ('CG', 2), ('FG', 2), ('AD', 2), ('AE', 2), ('AB', 1), ('AF', 1), ('AG', 1), ('AH', 1), ('CH', 1), ('DH', 1), ('EH', 1)]
'AC' 가 4번, 'CD' 가 3번, 'EH' 가 1번 주문되었다는 것을 의미한다.
아래의 menuList_[0][1] 값이 가장 많은 주문 횟수이며 조건에 의해 1보다 크다면 menuList_[0][1] 의 주문 횟수를 가진 조합된 메뉴가 '스카피'가 만들게 될 코스요리 메뉴 구성 후보이다.
from itertools import combinations
from collections import Counter
def solution(orders, course):
answer = []
for i in course:
menuList = []
for j in orders:
for e in combinations(j, i):
menuList.append(''.join(sorted(e)))
menuList_ = Counter(menuList).most_common()
for menu, cnt in menuList_:
if cnt > 1 and cnt == menuList_[0][1]:
answer.append(menu)
else:
break
answer = sorted(answer)
return answer
print(solution(['ABCFG', 'AC', 'CDE', 'ACDE', 'BCFG', 'ACDEH'], [2, 3, 4])) # ['AC', 'ACDE', 'BCFG', 'CDE']
'Coding Test' 카테고리의 다른 글
[프로그래머스] 실패율 (0) | 2021.08.22 |
---|---|
[프로그래머스] 괄호 변환 (0) | 2021.08.21 |
[프로그래머스] 문자열 압축 (0) | 2021.08.20 |
[프로그래머스] 신규 아이디 추천 (0) | 2021.08.19 |
[백준] 인공지능 시계 (0) | 2021.08.19 |
Comments