Algorithm/BOJ

λ°±μ€€(BOJ) 1931번 νšŒμ˜μ‹€λ°°μ • [그리디(Greedy)/μ•Œκ³ λ¦¬μ¦˜/파이썬(python)]

DAHLIA CHOI 2021. 8. 7. 22:53

 

 

1931번: νšŒμ˜μ‹€ λ°°μ •

(1,4), (5,7), (8,11), (12,14) λ₯Ό μ΄μš©ν•  수 μžˆλ‹€.

www.acmicpc.net

 

문제

ν•œ 개의 νšŒμ˜μ‹€μ΄ μžˆλŠ”λ° 이λ₯Ό μ‚¬μš©ν•˜κ³ μž ν•˜λŠ” N개의 νšŒμ˜μ— λŒ€ν•˜μ—¬ νšŒμ˜μ‹€ μ‚¬μš©ν‘œλ₯Ό λ§Œλ“€λ €κ³  ν•œλ‹€. 각 회의 I에 λŒ€ν•΄ μ‹œμž‘μ‹œκ°„κ³Ό λλ‚˜λŠ” μ‹œκ°„μ΄ μ£Όμ–΄μ Έ 있고, 각 νšŒμ˜κ°€ κ²ΉμΉ˜μ§€ μ•Šκ²Œ ν•˜λ©΄μ„œ νšŒμ˜μ‹€μ„ μ‚¬μš©ν•  수 μžˆλŠ” 회의의 μ΅œλŒ€ 개수λ₯Ό μ°Ύμ•„λ³΄μž. 단, νšŒμ˜λŠ” ν•œλ²ˆ μ‹œμž‘ν•˜λ©΄ 쀑간에 쀑단될 수 μ—†μœΌλ©° ν•œ νšŒμ˜κ°€ λλ‚˜λŠ” 것과 λ™μ‹œμ— λ‹€μŒ νšŒμ˜κ°€ μ‹œμž‘λ  수 μžˆλ‹€. 회의의 μ‹œμž‘μ‹œκ°„κ³Ό λλ‚˜λŠ” μ‹œκ°„μ΄ 같을 μˆ˜λ„ μžˆλ‹€. 이 κ²½μš°μ—λŠ” μ‹œμž‘ν•˜μžλ§ˆμž λλ‚˜λŠ” κ²ƒμœΌλ‘œ μƒκ°ν•˜λ©΄ λœλ‹€.

 

μž…λ ₯

첫째 쀄에 회의의 수 N(1 ≤ N ≤ 100,000)이 주어진닀. λ‘˜μ§Έ 쀄뢀터 N+1 μ€„κΉŒμ§€ 각 회의의 정보가 μ£Όμ–΄μ§€λŠ”λ° 이것은 곡백을 사이에 두고 회의의 μ‹œμž‘μ‹œκ°„κ³Ό λλ‚˜λŠ” μ‹œκ°„μ΄ 주어진닀. μ‹œμž‘ μ‹œκ°„κ³Ό λλ‚˜λŠ” μ‹œκ°„μ€ 231-1보닀 μž‘κ±°λ‚˜ 같은 μžμ—°μˆ˜ λ˜λŠ” 0이닀.

 

좜λ ₯

첫째 쀄에 μ΅œλŒ€ μ‚¬μš©ν•  수 μžˆλŠ” 회의의 μ΅œλŒ€ 개수λ₯Ό 좜λ ₯ν•œλ‹€.

 

 

✍ 예제 μ„€λͺ…

 

λͺ¨λ“  회의 일정을 μ„ μœΌλ‘œ λ‚˜νƒ€λ‚Ό λ•Œ, ν•œ νšŒμ˜μ‹€μ—μ„œ κ°€μž₯ λ§Žμ€ 회의λ₯Ό ν•  수 μžˆλŠ” μ΅œλŒ€κ°’μ€ 4이닀.

 


✍ 풀이방법

greedy μ•Œκ³ λ¦¬μ¦˜μ„ μ‚¬μš©ν•œλ‹€.

κ°€μž₯ λ§Žμ€ 회의λ₯Ό ν•  수 μžˆλŠ” 방법은 κ°€μž₯ 빨리 λλ‚˜λŠ” νšŒμ˜λ“€μ„ μ„ νƒν•˜λŠ” 방법이닀.

λ”°λΌμ„œ νšŒμ˜κ°€ λλ‚˜λŠ” μ‹œκ°„μ„ μ˜€λ¦„μ°¨μˆœμœΌλ‘œ μ •λ ¬ν•˜κ³ , λ‹€μŒμœΌλ‘œ λλ‚˜λŠ” 회의의 μ‹œμž‘μ‹œκ°„κ³Ό 전에 λλ‚¬λ˜ 회의의 λλ‚˜λŠ” μ‹œκ°„μ„ λΉ„κ΅ν–ˆμ„ λ•Œ μ‹œμž‘ μ‹œκ°„μ΄ λλ‚˜λŠ” μ‹œκ°„κ³Ό κ°™κ±°λ‚˜ 크면 countλ₯Ό 1올리면 λœλ‹€.

 

⭐ λλ‚˜λŠ” μ‹œκ°„μ„ μ˜€λ¦„μ°¨μˆœμœΌλ‘œ μ •λ ¬ν•˜λŠ”λ°, λλ‚˜λŠ” μ‹œκ°„μ€ 같은데 μ‹œμž‘ μ‹œκ°„μ΄ λ‹€λ₯Έ κ²½μš°μ— 비ꡐ가 잘 μ•ˆλ  μˆ˜λ„ 있         λ‹€!! κ·Έλž˜μ„œ κΌ­ κΌ­ μ‹œμž‘μ‹œκ°„μ„ λ¨Όμ € μ •λ ¬ν•œλ‹€μŒμ— λλ‚˜λŠ” μ‹œκ°„μ„ μ˜€λ¦„μ°¨μˆœμœΌλ‘œ ν•œ 번 더 ν•΄μ€€λ‹€. 그럼 λλ‚˜λŠ” μ‹œκ°„μ΄       λ™μΌν•΄λ„ λ¨Όμ € μ‹œμž‘ν•˜λŠ” νšŒμ˜κ°€ μ•žμ— μœ„μΉ˜ν•œλ‹€. 

 

 

πŸ“ μ½”λ“œ

import sys

def greedy_meeting_room(list):
    k = 0
    count = 1
    for i in range(1, len(list)):
        if list[k][1] <= list[i][0]:
            count += 1
            k = i
    return count

N = int(sys.stdin.readline())
list = [[0 for j in range(2)] for i in range(N)]

for i in range(N):
    start, finish = map(int, sys.stdin.readline().split())
    list[i][0], list[i][1] = start, finish
 
list.sort(key = lambda x : x[0]) # μ‹œμž‘μ‹œκ°„ μ •λ ¬
list.sort(key = lambda x : x[1]) # λλ‚˜λŠ” μ‹œκ°„ μ •λ ¬

print(greedy_meeting_room(list))