2021. 11. 27. 23:57ㆍ알고리즘/이분매칭
문제
N(1 ≤ N ≤ 100)마리의 들쥐들과 M(1 ≤ M ≤ 100)개의 땅굴이 있다. 각각의 들쥐는 2차원 평면상의 한 위치에 있고, 각각의 땅굴들도 2차원 평면상의 한 점에 위치한다.
들쥐들을 잡아먹는 매가 들쥐들을 습격했을 때, 쥐들은 매를 피하기 위해서 땅굴 속으로 숨을 수 있다. 모든 쥐들이 땅굴에 숨을 수 있다면 매에 잡아먹히는 쥐가 한 마리도 없겠지만, 각각의 땅굴에는 한 마리의 쥐만 들어갈 수 있을뿐더러 매가 도착하는 시간과 쥐들이 땅굴로 도망치는 속도가 있기 때문에 항상 모든 쥐들이 도망갈 수 있는 것은 아니다.
매는 현재를 기준으로 S(1 ≤ S ≤ 100)초가 지난 후에 지상에 도착한다. 각각의 들쥐들은 매 초당 V(1 ≤ V ≤ 100)만큼의 거리를 움직인다(즉 V가 쥐들의 초속이다). 만약 S초가 되기 전에 들쥐가 땅굴에 도착하게 되면 그 들쥐는 땅굴로 숨을 수 있다. 단, 들쥐가 도착하는 시간이 정확히 S인 경우에도 그 들쥐는 도망칠 수 있는 것으로 간주한다.
들쥐들은 종족 전체의 번영을 위해, 매에 잡아먹히게 되는 들쥐의 수가 최소가 되도록 도망치기로 하였다. 들쥐와 땅굴의 위치, 그리고 들쥐의 속도와 매가 도착하는 시간이 주어졌을 때, 잡아먹히게 되는 들쥐의 최소수를 구하는 프로그램을 작성하시오.
입력
첫째 줄에 네 정수 N, M, S, V가 주어진다. 다음 N개의 줄에는 들쥐의 x, y좌표가 주어지고, 그 다음 M개의 줄에는 땅굴의 x, y좌표가 주어진다. 모든 좌표는 절댓값이 1,000을 넘지 않는 실수이며 소숫점 셋째자리까지 주어질 수 있다.
출력
첫째 줄에 잡아먹히게 되는 들쥐의 최솟값을 출력한다.
예제 입력 1
2 2 5 10 1.0 1.0 2.0 2.0 100.0 100.0 20.0 20.0
예제 출력 1
1
접근 방법
- 각 들쥐들의 현재 위치를 기준으로 갈 수 있는 땅굴의 위치를 graph로 저장한다.
- 이를 이분매칭을 사용해 집합을 분리한다.
코드
# https://www.acmicpc.net/problem/2191
# 접근방법
# 각 들쥐들의 현재 위치를 기준으로 갈 수 있는 땅굴의 위치를 graph로 저장한다.
# 이를 이분매칭을 사용해 집합을 분리한다.
def dfs(idx):
if visited[idx]:
return False
visited[idx] = True
for x in graph[idx]:
if tunnel[x] == -1 or dfs(tunnel[x]):
tunnel[x] = idx
return True
return False
import math
n, m, s, v = map(float, input().split())
graph = [[] for _ in range(int(n))]
tunnel = [-1 for _ in range(int(m))]
mouse = [list(map(float, input().split())) for _ in range(int(n))]
for num in range(int(m)):
x1, y1 = map(float, input().split())
for i in range(int(n)):
x2, y2 = mouse[i]
if math.sqrt(abs(x1 - x2) ** 2 + abs(y1 - y2) ** 2) <= s * v:
graph[i].append(num)
count = 0
for i in range(int(n)):
visited = [False for _ in range(int(n))]
if dfs(i):
count += 1
print(int(n) - count)
'알고리즘 > 이분매칭' 카테고리의 다른 글
백준 온라인 저지, 이분매칭 / 2188번: 축사 (파이썬 / , 백준 플레티넘문제) (0) | 2021.12.07 |
---|---|
백준 온라인 저지, 이분매칭 / 11376번: 열혈강호2 (파이썬 / , 백준 플레티넘문제) (0) | 2021.12.06 |
백준 온라인 저지, 이분매칭 / 11375번: 열혈강호 (파이썬 / 백준 플래티넘문제) (0) | 2021.11.24 |
백준 온라인 저지, 이분매칭 / 1298번: 노트북의주인을찾아서 (파이썬 / 백준 플래티넘 문제) (0) | 2021.11.09 |
백준 온라인 저지, 이분매칭 / 9576번: 책나눠주기 (파이썬 / 백준 골드문제) (0) | 2021.08.29 |