본문 바로가기
BOJ

[Python] 백준 13414: 수강신청

by 야호호코코 2024. 7. 24.
반응형

 

solved.ac 기준 Silver 3

 

최대한 코드를 간결하고 명확하게 작성하려 생각하며 풀었던 문제이다. 슬럼프가 길어지고 있다. 책을 읽거나 cs공부를 더 함으로써 문해 능력을 더 길러야겠다. 글이 안읽혀서 손가락도 멈춘 느낌이 종종 든다.

문제

국민대학교에서는 매 학기 시작 전 종합정보시스템에서 수강신청을 한다. 매 수강신청마다 아주 많은 학생들이 몰려 서버에 많은 부하가 가기 때문에, 국민대학교에서는 수강신청 부하 관리 시스템을 도입하기로 결정하였다. 새로운 관리 시스템은 다음과 같은 방식으로 동작한다.

  1. 수강신청 버튼이 활성화 된 후, 수강신청 버튼을 조금이라도 빨리 누른 학생이 대기목록에 먼저 들어간다.
  2. 이미 대기열에 들어가 있는 상태에서 다시 수강신청 버튼을 누를 경우 대기목록의 맨 뒤로 밀려난다.
  3. 잠시 후 수강신청 버튼이 비활성화 되면, 대기목록에서 가장 앞에 있는 학생부터 자동으로 수강신청이 완료되며, 수강 가능 인원이 꽉 찰 경우 나머지 대기목록은 무시하고 수강신청을 종료한다.

위의 표는 최대 수강 가능 인원이 3명인 알고리즘 수업에 대해 6명의 학생이 수강신청을 진행한 모습이다. 버튼이 비활성화 된 후, 먼저 규칙 1을 적용하여 클릭을 2번 이상 한 학생의 중복된 대기목록을 삭제한다. 중복된 목록을 제거한 후, 맨 앞에서부터 최대 수강 가능 인원인 3명을 선정한다. 표의 맨 오른쪽에는 그 최종결과를 나타낸 모습이다. 이와 같은 방법을 이용하여 최종적으로 수강신청에 성공한 인원을 출력하는 프로그램을 작성하시오.

입력

입력 데이터는 표준 입력을 사용한다. 입력은 1개의 테스트 데이터로 구성된다. 입력의 첫 번째 줄에는 과목의 수강 가능 인원 K(1 ≤ K ≤ 100,000)와 학생들이 버튼을 클릭한 순서를 기록한 대기목록의 길이 L(1 ≤ L ≤ 500,000)이 주어진다. 두 번째 줄부터 L개의 줄에는 수강신청을 버튼을 클릭한 학생의 학번이 클릭 순서대로 주어진다. 학번은 8자리의 숫자로 이루어져 있다.

출력

출력은 표준 출력을 사용한다. 입력받은 데이터에 대해, 수강신청 관리 시스템의 규칙을 적용한 후 수강신청에 성공한 인원의 학번을 한 줄에 1개씩 출력한다.

예제 입력 1

3 8
20103324
20133221
20133221
20093778
20140101
01234567
20093778
20103325

예제 출력 1

20103324
20133221
20140101

 

정답 코드

K, L = map(int, input().split())

wait_queue = dict()

for i in range(L):
    num = input()
    wait_queue[num] = i

result = [(w, wait_queue[w]) for w in wait_queue]
result.sort(key=lambda x:x[1])

print('\n'.join(list(map(lambda x:x[0], result))[:K]))

 

 해시맵을 이용해야 시간복잡도에 걸리지 않고 풀 수 있다. 파이썬에는 dictionary라는 좋은 구조가 있기 때문에, 그대로 사용하면 된다. L개 만큼 계속 받으면서, wait_queue라는 딕셔너리에 계속 해당 이름을 key로 순서를 갱신해준다. (만약 나왔다가 또 나온다면, 가장 나중에 나온 순서가 자신의 순서이다.) 그리고 (이름, 순서) 쌍으로 리스트를 만들어 순서를 기준으로 정렬 한 뒤, join을 이용해 앞에서 부터 K개 만큼 깔끔하게 출력하면 끝

반응형

'BOJ' 카테고리의 다른 글

[Python] 백준 18405: 경쟁적 전염  (2) 2024.07.24
[Python] 백준 1972: 놀라운 문자열  (2) 2024.07.23
[Python] 백준 17836: 공주님을 구해라!  (0) 2024.07.19