[Baekjoon] 구슬 찾기
Updated:
문제
모양은 같으나, 무게가 모두 다른 N개의 구슬이 있다. N은 홀수이며, 구슬에는 번호가 1,2,…,N으로 붙어 있다. 이 구슬 중에서 무게가 전체의 중간인 (무게 순서로 (N+1)/2번째) 구슬을 찾기 위해서 아래와 같은 일을 하려 한다.
우리에게 주어진 것은 양팔 저울이다. 한 쌍의 구슬을 골라서 양팔 저울의 양쪽에 하나씩 올려 보면 어느 쪽이 무거운가를 알 수 있다. 이렇게 M개의 쌍을 골라서 각각 양팔 저울에 올려서 어느 것이 무거운가를 모두 알아냈다. 이 결과를 이용하여 무게가 중간이 될 가능성이 전혀 없는 구슬들은 먼저 제외한다.
예를 들어, N=5이고, M=4 쌍의 구슬에 대해서 어느 쪽이 무거운가를 알아낸 결과가 아래에 있다.
- 구슬 2번이 구슬 1번보다 무겁다.
- 구슬 4번이 구슬 3번보다 무겁다.
- 구슬 5번이 구슬 1번보다 무겁다.
- 구슬 4번이 구슬 2번보다 무겁다.
위와 같이 네 개의 결과만을 알고 있으면, 무게가 중간인 구슬을 정확하게 찾을 수는 없지만, 1번 구슬과 4번 구슬은 무게가 중간인 구슬이 절대 될 수 없다는 것은 확실히 알 수 있다. 1번 구슬보다 무거운 것이 2, 4, 5번 구슬이고, 4번 보다 가벼운 것이 1, 2, 3번이다. 따라서 답은 2개이다.
M 개의 쌍에 대한 결과를 보고 무게가 중간인 구슬이 될 수 없는 구슬의 개수를 구하는 프로그램을 작성하시오.
입력
첫 줄은 구슬의 개수를 나타내는 정수 N(1 ≤ N ≤ 99)과 저울에 올려 본 쌍의 개수 M(1 ≤ M ≤ N(N-1)/2)이 주어진다. 그 다음 M 개의 줄은 각 줄마다 두 개의 구슬 번호가 주어지는데, 앞 번호의 구슬이 뒤 번호의 구슬보다 무겁다는 것을 뜻한다.
출력
첫 줄에 무게가 중간이 절대로 될 수 없는 구슬의 수를 출력 한다.
예제
Example 1:
Input:
5 4
2 1
4 3
5 1
4 2
Output:
2
조건
시간 제한 : 1초
메모리 제한 : 128 MB
풀이과정
풀이 1
간단한 DFS문제. 구슬 각각에 대해 DFS를 적용하면 된다. 아직 모듈화(?)가 익숙치 않아서… 코드가 더러운 게 문제다.
from collections import deque
n, m = map(int, input().split())
# 가벼운 거 / 무거운 거 나눠서 따지기
graph1 = [[] for _ in range(n+1)]
graph2 = [[] for _ in range(n+1)]
for _ in range(m):
a, b = map(int, input().split())
graph1[a].append(b)
graph2[b].append(a)
ans = set()
for k in range(1, n+1):
q = deque()
visited = [False]*(n+1)
q.append((k, 1))
visited[k] = True
mark = 0
while q:
now, level = q.popleft()
if mark > n//2:
ans.add(k)
break
for v in graph1[now]:
if visited[v] == False:
visited[v] = True
q.append((v, level+1))
mark += 1
for k in range(1, n+1):
q = deque()
visited = [False]*(n+1)
q.append((k, 1))
visited[k] = True
mark = 0
while q:
now, level = q.popleft()
if mark > n//2:
ans.add(k)
break
for v in graph2[now]:
if visited[v] == False:
visited[v] = True
q.append((v, level+1))
mark += 1
print(len(ans))
Leave a comment