-
그리디 유형 문제 풀이 < 모험가 길드 >Python/알고리즘 2022. 8. 22. 22:29
문제 설명, 조건
● 한 마을에 모험가가 N명 있습니다. 모험가 길드에서는 N명의 모험가를 대상으로 '공포도'를 측정했는데, '공포도'가 높은 모험가는 쉽게 공포를 느껴 위험 상황에 제대로 대처할 능력이 떨어집니다.
● 모험가 길드장인 동빈이는 모험가 그룹을 안전하게 구성하고자 공포도가 X인 모험가는 반드시 X명 이상으로 구성한 모험가 그룹에 참여해야 여행을 떠날 수 있도록 규정했습니다.
● 동빈이는 최대 몇 개의 모험가 그룹을 만들 수 있는지 궁금합니다. N명의 모험가에 대한 정보가 주어졌을때, 여행을 떠날 수 있는 그룹 수의 최댓값을 구하는 프로그램을 작성하세요.
● 예를 들어 N = 5이고, 각 모험가의 공포도가 다음과 같다고 가정합시다.
2 3 1 2 2
● 이 경우 그룹 1에 공포도가 1, 2, 3인 모험가를 한 명씩 넣고, 그룹 2에 공포도가 2인 남은 두 명을 넣게 되면 총 2개의 그룹을 만들 수 있습니다.
● 또한 몇 명의 모험가는 마을에 그대로 남아 있어도 되기 때문에, 모든 모험가를 특정한 그룹에 넣을 필요는 없습니다.
● 입력 조건
첫째 줄에 모험가의 수 N이 주어집니다. (1 <= N <= 100,000)
둘째 줄에 각 모험가의 공포도의 값을 N 이하의 자연수로 주어지며, 각 자연수는 공백으로 구분합니다.
● 출력 조건
여행을 떠날 수 있는 그룹 수의 최댓값을 출력합니다.
● 입력 예시
5
2 3 1 2 2
● 출력 예시
2답안 예시
n = int(input())
data = list(map(int, input().split()))
data.sort()
result = 0 # 총 그룹의 수
count = 0 # 현재 그룹에 포홤된 모험가의 수
for i in data: # 공포도를 낮은 것부터 하나씩 확인하며
count += 1 # 현재 그룹에 해당 모험가를 포함시키기
if count >= i: # 현재 그룹에 포함된 모험가의 수가 현재의 공포도 이상이라면, 그룹 결성
result += 1 # 총 그룹의 수 증가시키기
count = 0 # 현재 그룹에 포함된 모험가의 수 초기화
print(result) # 총 그룹의 수 출력출처 : https://www.youtube.com/watch?v=2zjoKjt97vQ&list=PLRx0vPvlEmdAghTr5mXQxGpHjWqSz0dgC&index=3
'Python > 알고리즘' 카테고리의 다른 글
구현 유형 문제풀이 < 왕실의 나이트 > (0) 2022.08.25 구현 유형 문제풀이 < 시각 > (0) 2022.08.25 구현 유형 문제풀이 < 상하좌우 > (0) 2022.08.23 그리디 유형 문제 풀이 < 곱하기 혹은 더하기 > (0) 2022.08.22 그리디 유형 문제 풀이 < 1이 될 때까지 > (0) 2022.08.16