문제
- 한 마을에 모험가가 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())
fear = sorted(list(map(int, input().split())))
result = 0
cnt = 0
for i in fear :
cnt += 1 # 현재 그룹에 포함시키기
if cnt >= i : # 그룹인원수가 현재 공포도 이상이라면, 그룹이 형성될 수 있음
result += 1
cnt = 0
print(cnt)
- 공포도가 오름차순으로 정렬되어 있기 때문에, 항상 최소한의 모험가의 수만 포함하여 그룹을 결정하게 될 것이다.
- 즉, 항상 최적의 해를 찾을 수 있다.
'알고리즘 > 그리디' 카테고리의 다른 글
[백준] 1439번: 뒤집기 - 파이썬(python) (0) | 2022.09.29 |
---|---|
[이것이 코딩테스트다] 곱하기 혹은 더하기 - 파이썬(python) (0) | 2022.09.29 |
[프로그래머스] 단속카메라 - 파이썬(python) (0) | 2022.09.17 |
[프로그래머스] 섬 연결하기 - 파이썬(python) (0) | 2022.09.17 |
[프로그래머스] 구명보트 - 파이썬(python) (0) | 2022.09.16 |
댓글