오늘의 인기 글
최근 글
최근 댓글
Today
Total
11-29 00:00
관리 메뉴

우노

[Greedy] 이코테 “모험가 길드” Python 풀이 본문

Algorithm/Greedy

[Greedy] 이코테 “모험가 길드” Python 풀이

운호(Noah) 2022. 7. 26. 00:22

문제

  • 한 마을에 모험가가 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

풀이

  • 최대한 많은 그룹 수를 만드는 방법은, 최소한의 인원으로만 그룹을 구성하는 것이다.
  • 모든 모험가들이 전부 그룹화 될 필요는 없으므로, 그룹 결성이 가능한 모험가들로만 그룹을 결성하면 된다.
  • 따라서, 모험가들의 공포도를 오름차순 정렬한 뒤 순서대로 탐색하며, 그룹 결성이 가능한 최소한의 인원으로만 그룹 결성을 진행한다.
    • 현재까지 그룹에 포함된 인원이 탐색된 모험가의 공포도보다 크기만 하면, 바로 그룹을 결성해버린다.

예제 코드

import sys

# 모험가 수
n = int(sys.stdin.readline().rstrip())
# 공포도 배열
data = list(map(int, sys.stdin.readline().rstrip().split()))
# 공포도 배열 정렬
data.sort()

# 총 그룹의 수
result = 0
# 현재 그룹의 인원 수
count = 0

# 공포도 배열 탐색
for horror in data:
    # 현재 그룹에 인원 추가
    count += 1
    # 현재 그룹의 인원이 탐색한 공포도보다 크거나 같으면, 바로 그룹 결성
    if (count >= horror):
        result += 1
        count = 0 # 새로운 그룹을 결성해야하므로, 현재 그룹에 포함된 인원 수는 초기화

# 총 그룹의 수 출력
print(result)

참고

  • 이것이 취업을 위한 코딩 테스트다. with python
Comments