[백준]1931번 회의실 배정 - 그리디

2020. 12. 30. 16:28·SW개발/코딩테스트

 

n = int(input())
a = [[1]*2 for i in range(n)]
cnt = 0
check = 0

for i in range(n):
    a[i][0], a[i][1] = map(int, input().split())
a.sort(key=lambda x:(x[1], x[0]))

for i in range(n):
    if a[i][0] >= check:
        cnt += 1
        check = a[i][1]
        
print(cnt)

 

코드 설명

먼저 회의의 수를 위한 n, 회의의 정보를 위한 a 리스트, 회의의 최대 개수를 위한 cnt, 끝나는 시간을 체크하기 위한 check 변수를 선언한다. 그 후 회의 수 만큼 반복문을 통해 a 리스트에 회의의 정보를 전부 할당한 후, 정렬 함수를 통하여(lambda 사용) 끝나는 시간 순으로 정렬하고 그 뒤 기준은 시작 시간으로 하여 정렬한다. 

check 변수를 이용하여 만약 끝나는 시간보다 값이 크다면 중복이 되지 않으므로 이용할 수 있기에 cnt 를 1 증가시켜주고, check 변수의 값을 재 설정해준다.

 

Point : 회의의 끝나는 시간이 가장 적은 것이 중요하기에, 이를 기준으로 정렬을 하여야 한다. 그 뒤에는 끝나는 시간보다 시작시간이 작으면 회의실을 이용할 수 없기에 그 부분에서 통과되는 것만 카운트하면 최대 회의수를 구할 수 있게 된다.

728x90

'SW개발 > 코딩테스트' 카테고리의 다른 글

[백준]1541번 잃어버린 괄호 - 그리디  (0) 2021.01.01
[백준]11399번 ATM - 그리디  (0) 2020.12.31
[백준]11047번 동전 0 - 그리디  (1) 2020.12.27
[백준]10814번 나이순 정렬 - 정렬  (0) 2020.12.06
[백준]1181번 단어 정렬 - 정렬  (0) 2020.12.05
'SW개발/코딩테스트' 카테고리의 다른 글
  • [백준]1541번 잃어버린 괄호 - 그리디
  • [백준]11399번 ATM - 그리디
  • [백준]11047번 동전 0 - 그리디
  • [백준]10814번 나이순 정렬 - 정렬
Leffe_pt
Leffe_pt
개발자로서 성장하면서 배워온 지식과 경험을 공유하는 공간입니다.
  • Leffe_pt
    Leffe's tistory
    Leffe_pt
  • 전체
    오늘
    어제
    • 분류 전체보기 (307)
      • SW개발 (303)
        • 코딩테스트 (172)
        • 개발이야기 (23)
        • IT 용어 (17)
        • Python (22)
        • Django (46)
        • Flask (2)
        • Database (1)
        • SQLAlchemy (0)
        • Javascript (5)
        • Linux, Unix (3)
        • JAVA (2)
        • Spring (10)
      • 회고 (4)
      • 사진 (0)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    배달
    Contributor
    배달비 공유
    django
    플레이스토어
    트리 #AVL #알고리즘 #자료구조
    음식
    오픈소스
    라이프 스타일
    어플리케이션
    g
    배공파용
    컨트리뷰터
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
Leffe_pt
[백준]1931번 회의실 배정 - 그리디
상단으로

티스토리툴바