Algorithm/Greedy

(Python) - BOJ(2891번) : 카약과 강풍

하눤석 2022. 2. 1. 12:58
728x90

https://www.acmicpc.net/problem/2891

 

2891번: 카약과 강풍

첫째 줄에 팀의 수 N, 카약이 손상된 팀의 수 S, 카약을 하나 더 가져온 팀의 수 R이 주어진다. (2 ≤ N ≤ 10, 1 ≤ S, R ≤ N) 둘째 줄에는 카약이 손상된 팀의 번호가 주어진다. 팀 번호는 중복되지 않

www.acmicpc.net


  • 해설 : 

갑자기 엄청난 강풍이 경기장에 불었고, 일부 카약이 부서졌다. 경기는 5분 안에 시작해야 하는 상황이다.

 

다행히 일부 팀은 혹시 모를 사태에 대비해서 카약을 하나 더 경기장에 들고 왔다. 카약은 매우 무겁고 운반하기 어렵다. 따라서, 자신의 바로 다음이나 전에 경기하는 팀에게만 카약을 빌려주려고 한다. 즉, 팀 4는 여분의 카약을 3이나 5에게만 빌려줄 수 있다. 다른 팀에게서 받은 카약은 또 다른 팀에게 빌려줄 수 없다. 또, 카약을 하나 더 가져온 팀의 카약이 손상되었다면, 여분의 카약으로 경기에 출전하게되고, 이 카약은 다른 팀에게 빌려줄 수 없다.

 

카약이 부서진 팀과 하나 더 가져온 팀이 주어진다. 카약을 적절히 빌렸을 때 출발하지 못하는 팀의 최솟값은 몇 팀인지 구하는 프로그램을 작성하시오.

 

 

 


  • 풀이 :

우선 여분이 있는데 하나가 부서져서 여분을 본인이 사용해야 하는 경우를 체크해준다.  만약 빌려줄 수 있는 경우라면 왼쪽 팀부터 빌려주어 채워나가면 된다.

 

 

 


  • 소스코드 : 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
import sys
input = sys.stdin.readline
 
if __name__ == "__main__":
    N,S,R = map(int,input().split())
    B = list(map(int,input().split()))
    P = list(map(int,input().split()))
    ca = [0]*N
    for i in B:
        ca[i-1-= 1
    for i in P:
        ca[i-1+= 1
    stack = []
    
    for i in ca:
        if stack:
            if i == -1:
                if stack[-1== 1:
                    stack.pop()
                else:
                    stack.append(i)
            elif i == 1:
                if stack[-1== -1:
                    stack.pop()
                else:
                    stack.append(i)
            else:
                stack.append(i)
        else:
            stack.append(i)
    print(stack.count(-1))
cs
320x100