forked from ndb796/python-for-coding-test
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path2.py
35 lines (30 loc) Β· 1.16 KB
/
2.py
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
32
33
34
35
INF = int(1e9) # 무νμ μλ―Ένλ κ°μΌλ‘ 10μ΅μ μ€μ
# λ
Έλμ κ°μ, κ°μ μ κ°μλ₯Ό μ
λ ₯λ°κΈ°
n, m = map(int, input().split())
# 2μ°¨μ 리μ€νΈ(κ·Έλν νν)λ₯Ό λ§λ€κ³ , λͺ¨λ κ°μ 무νμΌλ‘ μ΄κΈ°ν
graph = [[INF] * (n + 1) for _ in range(n + 1)]
# μκΈ° μμ μμ μκΈ° μμ μΌλ‘ κ°λ λΉμ©μ 0μΌλ‘ μ΄κΈ°ν
for a in range(1, n + 1):
for b in range(1, n + 1):
if a == b:
graph[a][b] = 0
# κ° κ°μ μ λν μ 보λ₯Ό μ
λ ₯ λ°μ, κ·Έ κ°μΌλ‘ μ΄κΈ°ν
for _ in range(m):
# Aμμ Bλ‘ κ°λ λΉμ©μ 1λ‘ μ€μ
a, b = map(int, input().split())
graph[a][b] = 1
# μ νμμ λ°λΌ νλ‘μ΄λ μμ
μκ³ λ¦¬μ¦μ μν
for k in range(1, n + 1):
for a in range(1, n + 1):
for b in range(1, n + 1):
graph[a][b] = min(graph[a][b], graph[a][k] + graph[k][b])
result = 0
# κ° νμμ λ²νΈμ λ°λΌ ν λͺ
μ© νμΈνλ©° λλ¬ κ°λ₯νμ§ μ²΄ν¬
for i in range(1, n + 1):
count = 0
for j in range(1, n + 1):
if graph[i][j] != INF or graph[j][i] != INF:
count += 1
if count == n:
result += 1
print(result)